HashMap和Hashtable都是Map接口的典型实现类,它们之间的关系完全类似于ArrayList和Vector的关系:Hashtable是一个古老的Map实现类,它从JDK1.0起就已经出现了,当它出现时,Java还没有提供Map接口,所以它包含了两个繁琐的方法,即elements()(类似于Map接口定义的values()方法)和keys()(类似于Map接口定义的keySet()方法),现在很少使用这两个方法(关于这两个方法的用法请参考)
Java8改进了HashMap的实现,使用HashMap存在key冲突时依然具有较好的性能。
除此之外,Hashtable和HashMap存在两点典型区别。
(1)Hashtable是一个线程安全的Map实现,但HashMap是线程不安全的实现,所以HashMap比Hashtable的性能高一点;但如果有多个线程访问同一个Map对象时,使用Hashtable实现类会更好。
(2)Hashtable不允许使用null作为key和value,如果试图把null放进Hashtable中,将会引发空指针异常;但HashMap可以使用null作为key或value。
由于HashMap里的key不能重复,所以HashMap里最多只有一个key-value对的key为null,但可以有无数多个key-value对的value为null.
下面程序示范了用null值作为HashMap的key和value的情形。
package com.zhao.three;
import java.util.HashMap;
public class NullInHashMap {
public static void main(String[] args) {
HashMap hm=new HashMap<>();
hm.put(null, null);
hm.put(null, null);
hm.put("a", null);
System.out.println(hm);
}
}
上面程序试图向HashMap中放入三个key-value对,其中第二行代码处无法将key-value对放入,因为Map中已经有一个key-value对的key为null值,所以无法再放入key为null值的key-value对。第三行代码处可以放入该key-value对,因为一个HashMap中可以有多个value为null值。编译、运行上面程序,看到如下输出结果;