private final Node<K,V>[] initTable() {
Node<K,V>[] tab;
int sc;
//如果tab一直為null境氢,就一直進(jìn)行循環(huán),直到當(dāng)前線程獲取到Node數(shù)組
while ((tab = table) == null || tab.length == 0) {
//sizeCtl為-1時(shí)带欢,表示有其他線程正在進(jìn)行初始化
if ((sc = sizeCtl) < 0)
//這里yield()方法會(huì)告知調(diào)度器說(shuō)我要讓出CPU,重新恢復(fù)到就緒狀態(tài)。
//至于能不能成功讓出cpu讹剔,也不一定把沼。
//如果能成功讓出,當(dāng)前線程恢復(fù)到ready狀態(tài)秩伞,在等待再次運(yùn)行的過(guò)程當(dāng)中逞带。
//其他的線程可能已經(jīng)完成初始化了。這樣就可以直接返回tab纱新。
//如果沒(méi)有讓出展氓,那就繼續(xù)進(jìn)行while循環(huán),等待其他線程完成初始化工作脸爱。
Thread.yield(); // lost initialization race; just spin
//這里使用CAS原子操作對(duì)sizeCtl進(jìn)行修改遇汞。將原來(lái)的值,改成-1簿废。這里就說(shuō)明了空入,如果sizeCtl被成功修改成了-1,就表明有一個(gè)線程正在進(jìn)行初始化族檬。其他的線程再進(jìn)來(lái)的時(shí)候歪赢,拿到sizeCtl=-1。然后yield出CPU导梆。
else if (U.compareAndSwapInt(this, SIZECTL, sc, -1)) {
try {
/**
*設(shè)有兩個(gè)線程t1,t2都在進(jìn)行初始化操作轨淌。
*這個(gè)時(shí)候,t1已經(jīng)完成了初始化看尼,這個(gè)時(shí)候sizeCtl根據(jù)下面的邏輯應(yīng)該是12递鹉。
*而這時(shí)候,t2剛剛進(jìn)入到while循環(huán)中藏斩,這時(shí)候躏结,會(huì)重新給sizeCtl賦值成-1。
*賦值成功后狰域,如果沒(méi)有空判斷媳拴,則又會(huì)重新初始化一遍黄橘。
*/
if ((tab = table) == null || tab.length == 0) {
int n = (sc > 0) ? sc : DEFAULT_CAPACITY;
@SuppressWarnings("unchecked")
Node<K,V>[] nt = (Node<K,V>[])new Node<?,?>[n];
table = tab = nt;
sc = n - (n >>> 2);
}
} finally {
/**
*After initialization, holds the next element count value upon which to resize the table.
*
*根據(jù)這句話,我們可以得知屈溉,在完成初始化后塞关,sizeCtl的值被設(shè)置稱(chēng)為0.75*capacity
*/
sizeCtl = sc;
}
break;
}
}
return tab;
}
ConcurrentHashMap源碼閱讀#initTable
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
- 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)烤咧,“玉大人偏陪,你說(shuō)我怎么就攤上這事∷柘鳎” “怎么了竹挡?”我有些...
- 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)立膛。 經(jīng)常有香客問(wèn)我揪罕,道長(zhǎng),這世上最難降的妖魔是什么宝泵? 我笑而不...
- 正文 為了忘掉前任好啰,我火速辦了婚禮,結(jié)果婚禮上儿奶,老公的妹妹穿的比我還像新娘框往。我一直安慰自己,他們只是感情好闯捎,可當(dāng)我...
- 文/花漫 我一把揭開(kāi)白布椰弊。 她就那樣靜靜地躺著,像睡著了一般瓤鼻。 火紅的嫁衣襯著肌膚如雪秉版。 梳的紋絲不亂的頭發(fā)上,一...
- 那天茬祷,我揣著相機(jī)與錄音清焕,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛秸妥,可吹牛的內(nèi)容都是我干的滚停。 我是一名探鬼主播,決...
- 文/蒼蘭香墨 我猛地睜開(kāi)眼粥惧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼键畴!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起影晓,我...
- 序言:老撾萬(wàn)榮一對(duì)情侶失蹤镰吵,失蹤者是張志新(化名)和其女友劉穎檩禾,沒(méi)想到半個(gè)月后挂签,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
- 正文 獨(dú)居荒郊野嶺守林人離奇死亡盼产,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
- 正文 我和宋清朗相戀三年饵婆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片戏售。...
- 正文 年R本政府宣布锋喜,位于F島的核電站些己,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏嘿般。R本人自食惡果不足惜段标,卻給世界環(huán)境...
- 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望炉奴。 院中可真熱鬧逼庞,春花似錦、人聲如沸瞻赶。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)砸逊。三九已至璧南,卻和暖如春蜗元,著一層夾襖步出監(jiān)牢的瞬間损姜,已是汗流浹背秕硝。 一陣腳步聲響...
- 正文 我出身青樓哟沫,卻偏偏與公主長(zhǎng)得像欣范,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子拍柒,可洞房花燭夜當(dāng)晚...
推薦閱讀更多精彩內(nèi)容
- 前言 每一次總結(jié)都意味著重新開(kāi)始心傀,同時(shí)也是為了更好的開(kāi)始。ConcurrentHashMap 一直是我心中的痛拆讯。雖...
- 1.官方文檔的說(shuō)明 參考先前ConcurrentHashMap類(lèi)實(shí)現(xiàn)說(shuō)明翻譯: Treebins在搜索和相關(guān)操作中...
- hashMap中 table是一個(gè)含有 Entry 的數(shù)組脂男;初始化大小為initialCapacity,其中Ent...
- 一 API閱讀 這個(gè)類(lèi)的API算是比較長(zhǎng)的了种呐,逐字仔細(xì)看過(guò)宰翅。因?yàn)檫@個(gè)類(lèi)有點(diǎn)大而且內(nèi)容確實(shí)也足夠豐富,整個(gè)看完有些花...
- 1.源碼文檔相關(guān)說(shuō)明 參考先前ConcurrentHashMap類(lèi)實(shí)現(xiàn)說(shuō)明翻譯: 多線程協(xié)助擴(kuò)容會(huì)使得鎖等待時(shí)間變...