Java doc说-当哈希表中的条目数超过负载因子和当前容量的乘积时,哈希表被重新哈希
在下面的程序中 -
HashMap<Integer, String> map = new HashMap<Integer, String>();
int i = 1;
while(i<16) {
map.put(i, new Integer(i).toString());
i++;
}
Key 是Integer类型,在插入第 13 到第 15 个元素时,HashMap 容量保持为 16,阈值保持为 12,为什么?
在地图中添加第 13 个元素后调试屏幕截图 -
args String[0] (id=16)
map HashMap<K,V> (id=19)
entrySet null
hashSeed 0
KeySet null
loadFactor 0.75
modCount 13
size 13
table HashMap$Entry<K,V>[16] (id=25)
threshold 12
values null
i 14
[null, 1=1, 2=2, 3=3, 4=4, 5=5, 6=6, 7=7, 8=8, 9=9, 10=10, 11=11, 12=12, 13=13, null, null]
带有 String 类型键的 HashMap -HashMap<String, String>
或自定义类 -Map<Employee,Integer>
在第 13 次插入时显示预期行为