一、基本介绍
HashMap和Hashtable都是Java中的集合类,它们的主要功能是存储键值对。HashMap和Hashtable有很多共同点,但是也存在一些区别。
二、线程安全性
Hashtable是线程安全的,而HashMap是非线程安全的。由于Hashtable支持多线程同时写入数据,因此保证了线程安全,在多线程应用中比较常用;而HashMap在多线程情况下,需要使用同步机制来保证线程安全,否则会出现数据不一致的问题。
Hashtable示例:
Hashtablehashtable = new Hashtable<>(); hashtable.put(1, "Java");
HashMap示例:
MaphashMap = new HashMap<>(); hashMap.put(1, "Java");
三、键和值的null值
Hashtable中,如果键值为null或者value为null,会直接抛出NullPointerException异常。而HashMap允许键为null值,也允许值为null。
Hashtable示例:
Hashtablehashtable = new Hashtable<>(); hashtable.put(null, "Java");//会抛出NullPointerException异常 hashtable.put(1, null);//会抛出NullPointerException异常
HashMap示例:
MaphashMap = new HashMap<>(); hashMap.put(null, "Java");//可以正常插入 hashMap.put(1, null);//可以正常插入
四、迭代器
Hashtable的枚举器(Enumerator)只允许在集合初始化时使用,而不允许在修改过程中使用。而HashMap的迭代器(Iterator)是fail-fast迭代器,可以在并发时抛出ConcurrentModificationException异常。
Hashtable示例:
Hashtablehashtable = new Hashtable<>(); Enumeration keys = hashtable.keys(); while (keys.hasMoreElements()) { Integer key = keys.nextElement(); System.out.println(key + ":" + hashtable.get(key)); } //在修改hash表的过程中,使用keys都会抛出异常
HashMap示例:
MaphashMap = 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示例:
Hashtablehashtable = 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示例:
MaphashMap = 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。