java中Hashtable和HashMap的区别分析
2016-02-23 10:05
537 查看
java中Hashtable和HashMap的区别分析
作者: 字体:[增加 减小] 类型:转载 时间:2013-04-14 我要评论java中Hashtable和HashMap的区别分析,需要的朋友可以参考一下
1、Hashtable是Dictionary的子类,
复制代码 代码如下:
public class Hashtable<K,V>
extends Dictionary<K,V>
implements Map<K,V>, Cloneable, java.io.Serializable
HashMap:
复制代码 代码如下:
public class HashMap<K,V>
extends AbstractMap<K,V>
implements Map<K,V>, Cloneable, Serializable
HashMap和Hashtable都是Map接口的一个实现类;
2、Hashtable中的方法是同步的(),而HashMap中的方法在默认情况下不是同步的。即是说,在多线程应用程序中,不用专门的操作就安全地可以使用Hashtable了;而对于HashMap,则需要额外的同步机制。但HashMap的同步问题可通过Collections的一个静态方法得到解决:
复制代码 代码如下:
public static <K,V> Map<K,V> synchronizedMap(Map<K,V> m)
这个方法返回一个同步的Map,也就是说返回的Map是线程安全的。需要注意的是,对返回的map进行迭代时,必须手动在返回的map上进行同步,否则将会导致不确定的行为:
复制代码 代码如下:
Map m = Collections.synchronizedMap(new HashMap());
...
Set s = m.keySet(); // Needn't be in synchronized block
...
synchronized(m) { // Synchronizing on m, not s!
Iterator i = s.iterator(); // Must be in synchronized block
while (i.hasNext())
foo(i.next());
}
3.在HashMap中,null可以作为键,这样的键只有一个;可以有一个或多个键所对应的值为null。当get()方法返回null值时,即可以表示HashMap中没有该键,也可以表示该键所对应的值为null。因此,在HashMap中不能由get()方法来判断HashMap中是否存在某个键,而应该用containsKey()方法来判断。Hashtable的键值不能为null,否则:java.lang.NullPointerException 。
4.HashTable使用Enumeration,HashMap使用Iterator。
以上只是表面的不同,它们的实现也有很大的不同。
5.HashTable中hash数组默认大小是11,增加的方式是 old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。
6.哈希值的使用不同,HashTable直接使用对象的hashCode,代码是这样的:
复制代码 代码如下:
int hash = key.hashCode();
int index = (hash & 0x7FFFFFFF) % tab.length;
而HashMap重新计算hash值,而且用与代替求模,比如HashMap的put方法:
复制代码 代码如下:
public V put(K key, V value) {
if (key == null)
return putForNullKey(value);
int hash = hash(key.hashCode());
int i = indexFor(hash, table.length);
for (Entry<K,V> e = table[i]; e != null; e = e.next) {
Object k;
if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
V oldValue = e.value;
e.value = value;
e.recordAccess(this);
return oldValue;
}
}
modCount++;
addEntry(hash, key, value, i);
return null;
}
复制代码 代码如下:
static int hash(int h) {
// This function ensures that hashCodes that differ only by
// constant multiples at each bit position have a bounded
// number of collisions (approximately 8 at default load factor).
h ^= (h >>> 20) ^ (h >>> 12);
return h ^ (h >>> 7) ^ (h >>> 4);
}
复制代码 代码如下:
static int indexFor(int h, int length) {
return h & (length-1);
}
您可能感兴趣的文章:
浅析java中ArrayList与Vector的区别以及HashMap与Hashtable的区别浅析Java中Map与HashMap,Hashtable,HashSet的区别
Java中HashMap和Hashtable及HashSet的区别
Java中HashMap和Hashtable的区别浅析
Java中Hashtable类与HashMap类的区别详解
相关文章推荐
- Eclipse中导入外部jar包(自用)
- Eclipae常用快捷键 Java代码
- Java中使用Jar包时读取当前jar文件所在的目录工具
- Java transient关键字的使用
- java 图片质量压缩
- [Spring]02_Spring框架和MVC原理
- java实现定时任务的三种方法
- java spring mvc时间String转Date(二)
- Java transient关键字使用
- myeclipse添加server library
- Java生成验证码工具
- Java 反射机制 .class .getClass() Class.forName("") .TYPE int void
- Eclipse修改svn地址
- 使用SpringSecurity3用户验证(异常信息,验证码)
- JAVA_面向对象_练习_封装_02_EncapsulationDaemon02.java
- JAVA_面向对象_练习_封装_02_EncapsulationDaemon02.java
- Struts2动态方法调用
- 【转】java中三个类别加载器的关系以及各自加载的类的范围
- JAVA_面向对象_练习_封装_01_EncapsulationDaemon01.java
- JAVA_面向对象_练习_封装_01_EncapsulationDaemon01.java