java中map用法 java concurrent map能鎖住整個(gè)map嗎?
java concurrent map能鎖住整個(gè)map嗎?無法鎖定。并發(fā)映射的鎖粒度不是整個(gè)映射,而是其中的片段,即片段。提高并發(fā)效率。多個(gè)線程可以讀一個(gè)變量,只有一個(gè)線程可以對(duì)這個(gè)變量進(jìn)行寫,到底要
java concurrent map能鎖住整個(gè)map嗎?
無法鎖定。并發(fā)映射的鎖粒度不是整個(gè)映射,而是其中的片段,即片段。提高并發(fā)效率。
多個(gè)線程可以讀一個(gè)變量,只有一個(gè)線程可以對(duì)這個(gè)變量進(jìn)行寫,到底要不要加鎖?
下面簡(jiǎn)要說明以下原因:
鎖定是因?yàn)椴僮鞑皇窃拥?。讓我們用操作一來解釋它??聪旅鎯蓚€(gè)圖。
我這個(gè)操作需要
看上面的第二個(gè)圖,你能很清楚地理解這個(gè)過程嗎?
鎖定是為了確保上述三個(gè)步驟是原子操作。
回到問題上來,只有一個(gè)線程要寫,沒有競(jìng)爭(zhēng),所以不需要鎖定。
但是,如果你看第一張圖片,因?yàn)橹鲀?nèi)存和本地內(nèi)存的存在
在一個(gè)線程寫入后,其他線程無法立即看到它。這就是可見性問題。
添加volatile關(guān)鍵字后,它將在操作后強(qiáng)制工作內(nèi)存和主內(nèi)存同步,以確保其他線程可以立即看到它。
java concurrenthashmap put的時(shí)候要加鎖嗎?
無需鎖定。Java并發(fā)HashMap在內(nèi)部實(shí)現(xiàn)了鎖機(jī)制。并發(fā)HashMap類包含兩個(gè)靜態(tài)內(nèi)部類:hashentry和segment。Hashentry用于封裝映射表的鍵/值對(duì);segment用作鎖,每個(gè)segment對(duì)象保護(hù)整個(gè)hash映射表的幾個(gè)bucket。每個(gè)bucket都是hashentry對(duì)象的鏈表。并發(fā)HashMap實(shí)例包含多個(gè)段對(duì)象的數(shù)組。