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