Map中自定义对象做KEY
Map作为java中常用数据结构,在写程序中时经常需要用到,主要讲述在使用Map时自定义KEY注意事项。
一、Map存储形态(以HashMap为例)
在介绍HashMap时首先上一段java源码:
public V put(K key, V value) {
if (table == EMPTY_TABLE) {
inflateTable(threshold);
}
if (key == null)
return putForNullKey(value);
int hash = hash(key);
int i = indexFor(hash, table.length);
for (Entry<K,V> e = table[i]; e != null; e = e.next) {
Object k;
if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
V oldValue = e.value;
e.value = value;
e.recordAccess(this);
return oldValue;
}
}
modCount++;
addEntry(hash, key, value, i);
return null;
}
上面这段代码摘录自java源码中关于HashMap在push元素时代码,本处插一段废话,在JAVA面试时经常会被问到HashMap和HashTable有什么区别,此段代码就说明一个区别,HashMap是支持NULL类型KEY(另外区别是:HashTable是线程安全,HashMap非线程安全),回到正题:
1) 首先判断KEY是否为NULL,对应的代码为:
if (key == null)
return