java線程鎖有幾種 多個(gè)線程可以讀一個(gè)變量,只有一個(gè)線程可以對(duì)這個(gè)變量進(jìn)行寫(xiě),到底要不要加鎖?
多個(gè)線程可以讀一個(gè)變量,只有一個(gè)線程可以對(duì)這個(gè)變量進(jìn)行寫(xiě),到底要不要加鎖?下面簡(jiǎn)要解釋一下原因:鎖定是因?yàn)椴僮鞑皇窃拥?。讓我們用操作一?lái)解釋它??聪旅鎯蓚€(gè)圖。我這個(gè)操作需要看上面的第二個(gè)圖,你能很清
多個(gè)線程可以讀一個(gè)變量,只有一個(gè)線程可以對(duì)這個(gè)變量進(jìn)行寫(xiě),到底要不要加鎖?
下面簡(jiǎn)要解釋一下原因:
鎖定是因?yàn)椴僮鞑皇窃拥?。讓我們用操作一?lái)解釋它??聪旅鎯蓚€(gè)圖。
我這個(gè)操作需要
看上面的第二個(gè)圖,你能很清楚地理解這個(gè)過(guò)程嗎?
鎖定是為了確保上述三個(gè)步驟是原子操作。
回到問(wèn)題上來(lái),只有一個(gè)線程要寫(xiě),沒(méi)有競(jìng)爭(zhēng),所以不需要鎖定。
但是,如果你看第一張圖片,因?yàn)橹鲀?nèi)存和本地內(nèi)存的存在
在一個(gè)線程寫(xiě)入后,其他線程無(wú)法立即看到它。這就是可見(jiàn)性問(wèn)題。
添加volatile關(guān)鍵字后,它將在操作后強(qiáng)制工作內(nèi)存和主內(nèi)存同步,以確保其他線程可以立即看到它。
多線程編程的時(shí)候,使用無(wú)鎖結(jié)構(gòu)會(huì)不會(huì)比有鎖結(jié)構(gòu)更加快?
這是毫無(wú)疑問(wèn)的,因?yàn)榫€程鎖定是資源密集型的
!那么,如何避免鎖的性能下降呢?
1、從業(yè)務(wù)上避免大量鎖結(jié)構(gòu)
!2. 使用ThreadLocal,可以保證每個(gè)線程中的數(shù)據(jù)不會(huì)互相污染
!3. 如果讀多寫(xiě)少,請(qǐng)使用讀寫(xiě)鎖
!4. 自旋鎖將挑戰(zhàn)CPU,盡管它是一個(gè)線程時(shí)間很少的鎖
!5. 鎖的粒度應(yīng)該盡可能小:如果鎖可以在方法中,不要占用整個(gè)方法
本書(shū)推薦用于Java并發(fā)編程實(shí)踐。
本書(shū)從并發(fā)和線程安全的基本概念出發(fā),介紹如何使用類(lèi)庫(kù)提供的基本并發(fā)構(gòu)建塊來(lái)避免并發(fā)風(fēng)險(xiǎn)、構(gòu)造線程安全類(lèi)和驗(yàn)證線程安全規(guī)則。
如何將較小的線程安全類(lèi)組合成較大的線程安全類(lèi),如何使用線程提高并發(fā)應(yīng)用程序的吞吐量,如何識(shí)別可并行執(zhí)行的任務(wù),如何提高單行程序子系統(tǒng)的響應(yīng)能力,如何確保并發(fā)程序執(zhí)行預(yù)期的任務(wù),以及如何提高并發(fā)代碼的性能和可擴(kuò)展性。
最后,介紹了一些高級(jí)主題,如顯式鎖定、原子變量、非阻塞算法以及如何開(kāi)發(fā)自定義同步工具類(lèi)。
總之,本書(shū)介紹完整,原理分析透徹。我希望我的回答能幫助你。