为什么HashMap的key允许空值,而Hashtable却不允许

结论:HashMap对象的key、value值均可为null。

           Hashtable对象的key、value值均不可为null。

且两者的的key值均不能重复,若添加key相同的键值对,后面的value会自动覆盖前面的value,但不会报错。

 

1.从源码分析

HashMap从源码分析:

HashMap在put的时候会调用hash()方法来计算key的hashcode值,可以从hash算法中看出当key==null时返回的值为0。因此key为null时,hash算法返回值为0,不会调用key的hashcode方法。

HashTable从源码分析:

上面可以看出当Hashtable存入的value为null时,抛出NullPointerException异常。如果value不为null,而key为空,在执行到int  hash = key.hashCode()时同样会抛出NullPointerException异常

2.从设计师角度分析
Hashtable是Java中的遗留类,现在不怎么用了,这里HashMap vs Hashtable有个解释。也许Hashtable类的设计者当时认为null作为key 和value 是没有什么用的。

HashMap是之后的版本引进的类,它的接口Map表达的意义更为广泛,也许HashMap的设计者认为null作为key和value是有实际意义的,所以才允许为null.

当然实际项目中,真的是有value为null的情况的。key为null的情况比较少见,但不代表没有。HashMap允许null为key和value应当是类的设计者思考让这个类更有用的设计吧。
--------------------- 
原文:https://blog.csdn.net/codeHaoHao/article/details/85392932 
 

猜你喜欢

转载自blog.csdn.net/HD243608836/article/details/88052088