OK,现在咋们来看一下底层原理:
HashMap
Map<String,String> map=new HashMap<>();
map.put(null,"123");
system.out.println(map);
static final int hash(Object key) {
int h;
return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
}
这里有一个三目运算符判断key是否为空,如果是,则为0
HashTable
如果值为null,则会抛出异常
public synchronized V put(K key, V value) {
// Make sure the value is not null
if (value == null) {
throw new NullPointerException();
}
上面可以看出当HashTable存入的value为null时,抛出NullPointerException异常。如果value不为null,而
key为空,在执行到int hash = key.hashCode()时同样会抛出NullPointerException异常
从设计师角度分析
HashTable是Java中的遗留类,现在不怎么用了,这里HashMap vs HashTable有个解释。也许HashTable
类的设计者当时认为null作为key和value是没有什么用的。
HashMap是之后的版本引进的类,它的接口Map表达的意义更为广泛,也许HashMap的设计者认为null
司
作为key和value是有实际意义的,所以才允许为null.
当然实际项目中,真的是有value为null的情况的。key为null的情况比较少见,但不代表没有。HashMap
允许null为key和value应当是类的设计者思考让这个类更有用的设计吧。