JobPlus知识库 IT 软件开发 文章
Java - HashMap和Hashtable的区别

比较HashMap和Hashtable

1)  Hashtable是线程安全的(即定义在Hashtable中的方法),但HashMap不是。如果你想使一个HashMap是线程安全的,可以使用 Collections.synchronizedMap(map) 或者ConcurrentHashMap类。
Hashtabe中的同步方法是如下定义的

public synchronized boolean contains(Object obj){ ... }public synchronized boolean containsKey(Object obj){ ... }public synchronized Object get(Object obj){ ... }public synchronized Object put(Object obj, Object obj1){ ... }public synchronized Object remove(Object obj){ ... }

2) Hashtable不允许空(null)的键或值。HashMap允许一个空键(其他的空键会覆盖第一个空键)和任意数量的空值。

Hashtable<String, String> hashTable = new Hashtable<String, String>(); hashTable.put(null, "value");//ORhashTable.put("key", null); Output: Exception in thread "main" java.lang.NullPointerException    at java.util.Hashtable.hash(Unknown Source)    at java.util.Hashtable.put(Unknown Source)    at test.core.MapExamples.main(MapExamples.java:12)

3) Hashtable从Java语言问世的以来就已经存在,而HashMap是在Java集合框架诞生作为其一部分新出现的(JDK 1.2)。还要注意正如Java docs所声明的Hashtable继承Dictionary类,而在新的JDK版本中被替换成实现Map接口

//HashTable is defined aspublic class Hashtable extends Dictionary implements Map, Cloneable, Serializable {}//HashMap is defined aspublic class HashMap extends AbstractMap implements Map, Cloneable, Serializable {}

4) HashMap的迭代器(Iterator)是快速失败(fail-fast)的,如果其他线程不用迭代器本身的remove()方法,而通过别的add或remove任何元素,从而修改了Map的中的数据,那么会抛出ConcurrentModificationException,JVM会尽力,但这并不是一个有保证的行为。Hashtable的枚举器(Enumerator)不是快速失败的(fail-fast)。

HashMap<String, String> hashMap = new HashMap<String, String>(); hashMap.put("key1", "value1"); hashMap.put("key2", "value2"); hashMap.put("key3", "value3"); hashMap.put("key4", "value4"); Iterator<String> iterator = hashMap.keySet().iterator();while(iterator.hasNext()){    iterator.next();    iterator.remove();    System.out.println(hashMap); } Output: {key3=value3, key2=value2, key1=value1} {key2=value2, key1=value1} {key1=value1} {}

5) 最后,Map接口修正了一个Hashtable的小缺陷。Hashtable有一个方法contains(),但方法名并不明确到底包含键,还是包含值,在Map接口中被删掉,只留下了containsValue() 和containsKey()。

public boolean containsKey(Object obj) {...}public boolean containsValue(Object obj) {...}

对于HashMap和Hashtable使用建议

几乎没有任何工作是只能Hashtable做,而HashMap及其相关的类(如LinkedHashMap或者ConcurrentHashMap)不能完成的。所以,您编写的代码没有很好的理由使用Hashtable。总是优先实用HashMap

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!

¥ 打赏支持
374人赞 举报
分享到
用户评价(0)

暂无评价,你也可以发布评价哦:)

扫码APP

扫描使用APP

扫码使用

扫描使用小程序