<1> HashMap计算key的hash值时调用单独的方法,在该方法中会判断key是否为null,如果是则返回0,可存在一个为null的key,value值可为null;而Hashtable中则直接调用key的hashCode()方法,因此如果key为null,则抛出空指针异常。
<2> HashMap将键值对添加进数组时,不会主动判断value是否为null;而Hashtable则首先判断value是否为null。
<3>Hashtable继承自Dictionary,而HashMap继承自AbstractMap。
<4>原因主要是由于三者都是重写了来自父类的put方法,但是Hashtable的源码中put方法声明了不能为null的代码
而HashMap的putVal方法并没有声明为null报异常的代码
虽然ConcurrentHashMap也继承自AbstractMap,但是其putVal方法中过滤掉了key或value为null的键值对。