面試官:并發(fā)下的 HashMap 為什么會(huì)引起死循環(huán)???
點(diǎn)擊上方“碼農(nóng)突圍”,馬上關(guān)注 這里是碼農(nóng)充電第一站,回復(fù)“666”,獲取一份專屬大禮包 真愛,請(qǐng)?jiān)O(shè)置“星標(biāo)”或點(diǎn)個(gè)“在看”

/**
*
* 往表中添加元素,如果插入元素之后,表長(zhǎng)度不夠,便會(huì)調(diào)用resize方法擴(kuò)容
*/
void addEntry(int hash, K key, V value, int bucketIndex) {
Entry<K,V> e = table[bucketIndex];
table[bucketIndex] = new Entry<K,V>(hash, key, value, e);
if (size++ >= threshold)
resize(2 * table.length);
}
/**
* resize()方法如下,重要的是transfer方法,把舊表中的元素添加到新表中
*/
void resize(int newCapacity) {
Entry[] oldTable = table;
int oldCapacity = oldTable.length;
if (oldCapacity == MAXIMUM_CAPACITY) {
threshold = Integer.MAX_VALUE;
return;
}
Entry[] newTable = new Entry[newCapacity];
transfer(newTable);
table = newTable;
threshold = (int)(newCapacity * loadFactor);
}
/**
* Transfers all entries from current table to newTable.
*/
void transfer(Entry[] newTable, boolean rehash) {
int newCapacity = newTable.length;
for (Entry<K,V> e : table) {
while(null != e) {
Entry<K,V> next = e.next; ---------------------(1)
if (rehash) {
e.hash = null == e.key ? 0 : hash(e.key);
}
int i = indexFor(e.hash, newCapacity);
e.next = newTable[i];
newTable[i] = e;
e = next;
} // while
}
}
Map<Integer> map = new HashMap<Integer>(2); // 只能放置兩個(gè)元素,其中的threshold為1(表中只填充一個(gè)元素時(shí)),即插入元素為1時(shí)就擴(kuò)容(由addEntry方法中得知)
//放置2個(gè)元素 3 和 7,若要再放置元素8(經(jīng)hash映射后不等于1)時(shí),會(huì)引起擴(kuò)容

e = 3
next = 7




- END - 最近熱文
? 永別了,91網(wǎng)站!宣布永久關(guān)閉 ? 騰訊員工曬出薪資:真實(shí) 985 畢業(yè)薪資,大家看我還有救嗎?網(wǎng)友:日薪? ? 再見深圳!我要去成都搞IT了! ? 一個(gè)員工的離職成本到底有多恐怖!
評(píng)論
圖片
表情
