您的位置:

HashMap和Hashtable的区别

一、基本介绍

HashMap和Hashtable都是Java中的集合类,它们的主要功能是存储键值对。HashMap和Hashtable有很多共同点,但是也存在一些区别。

二、线程安全性

Hashtable是线程安全的,而HashMap是非线程安全的。由于Hashtable支持多线程同时写入数据,因此保证了线程安全,在多线程应用中比较常用;而HashMap在多线程情况下,需要使用同步机制来保证线程安全,否则会出现数据不一致的问题。

Hashtable示例:

Hashtable hashtable = new Hashtable<>();
hashtable.put(1, "Java");

  

HashMap示例:

Map hashMap = new HashMap<>();
hashMap.put(1, "Java");

  

三、键和值的null值

Hashtable中,如果键值为null或者value为null,会直接抛出NullPointerException异常。而HashMap允许键为null值,也允许值为null。

Hashtable示例:

Hashtable hashtable = new Hashtable<>();
hashtable.put(null, "Java");//会抛出NullPointerException异常
hashtable.put(1, null);//会抛出NullPointerException异常

  

HashMap示例:

Map hashMap = new HashMap<>();
hashMap.put(null, "Java");//可以正常插入
hashMap.put(1, null);//可以正常插入

  

四、迭代器

Hashtable的枚举器(Enumerator)只允许在集合初始化时使用,而不允许在修改过程中使用。而HashMap的迭代器(Iterator)是fail-fast迭代器,可以在并发时抛出ConcurrentModificationException异常。

Hashtable示例:

Hashtable hashtable = new Hashtable<>();
Enumeration
    keys = hashtable.keys();
while (keys.hasMoreElements()) {
    Integer key = keys.nextElement();
    System.out.println(key + ":" + hashtable.get(key));
}
//在修改hash表的过程中,使用keys都会抛出异常

   
  

HashMap示例:

Map hashMap = new HashMap<>();
Iterator
    iterator = hashMap.keySet().iterator();
while (iterator.hasNext()) {
    Integer key = iterator.next();
    System.out.println(key + ":" + hashMap.get(key));
}
hashMap.put(2, "C++");
iterator.next();//抛出ConcurrentModificationException异常

   
  

五、性能

Hashtable和HashMap的性能问题,主要是因为桶的初始值问题所导致的。Hashtable默认初始值是11,而HashMap默认初始值是16。

Hashtable示例:

Hashtable hashtable = new Hashtable<>();
long start = System.currentTimeMillis();
for (int i = 0; i < 1000000; i++) {
    hashtable.put(i, "Java");
}
long end = System.currentTimeMillis();
System.out.println("Hashtable put 1000000 elements consumes: " + (end - start) + " ms.");

  

HashMap示例:

Map hashMap = new HashMap<>();
long start = System.currentTimeMillis();
for (int i = 0; i < 1000000; i++) {
    hashMap.put(i, "Java");
}
long end = System.currentTimeMillis();
System.out.println("HashMap put 1000000 elements consumes: " + (end - start) + " ms.");

  

六、总结

通过以上对HashMap和Hashtable的比较,我们可以知道HashMap比Hashtable更为常用,因为HashMap不仅性能更好,而且允许键值对为空值。当然,如果需要在多线程的环境下使用,就需要使用Hashtable。