foreach遍歷list集合 求各位大神,Java多線程看哪本書好?
求各位大神,Java多線程看哪本書好?推薦java并發(fā)編程實(shí)戰(zhàn)這本書。這本書從并發(fā)性和線程安全性的基本概念出發(fā),介紹了如何使用類庫提供的基本并發(fā)構(gòu)建塊,用于避免并發(fā)危險、構(gòu)造線程安全的類及驗(yàn)證線程安全
求各位大神,Java多線程看哪本書好?
推薦java并發(fā)編程實(shí)戰(zhàn)這本書。
這本書從并發(fā)性和線程安全性的基本概念出發(fā),介紹了如何使用類庫提供的基本并發(fā)構(gòu)建塊,用于避免并發(fā)危險、構(gòu)造線程安全的類及驗(yàn)證線程安全的規(guī)則。
如何將小的線程安全類組合成更大的線程安全類,如何利用線程來提高并發(fā)應(yīng)用程序的吞吐量,如何識別可并行執(zhí)行的任務(wù),如何提高單線程子系統(tǒng)的響應(yīng)性,如何確保并發(fā)程序執(zhí)行預(yù)期任務(wù),如何提高并發(fā)代碼的性能和可伸縮性等內(nèi)容。
最后介紹了一些高級主題,如顯式鎖、原子變量、非阻塞算法以及如何開發(fā)自定義的同步工具類。
總之,書中介紹的比較全,原理解析比較透徹。希望我的回答能幫到你。
多個線程可以讀一個變量,只有一個線程可以對這個變量進(jìn)行寫,到底要不要加鎖?
先說結(jié)論:不必要
- 如果不需要可見性,什么都不需要加
- 如果需要保證可見性,則需要加volatile關(guān)鍵字。這里可以加鎖,但是沒必要,對性能有影響
下面簡單解釋下原因:
加鎖是因?yàn)椴僮鞑皇窃有缘?,以i 這個操作來解釋,看下面兩張圖。
i 這個操作需要
- 先將i的值從內(nèi)存中讀出來
- 然后加1
- 最后寫回去
看上面第二張圖,能很清楚的理解流程吧?
加鎖就是保證上面的三步是一個原子操作。
回到問題,這里只有一個線程寫,實(shí)際沒有競爭,所以沒必要加鎖。
但是,看第一張圖,因?yàn)橛兄鲀?nèi)存和本地內(nèi)存的存在
- 線程先寫入本地內(nèi)存
- 然后刷入主內(nèi)存
- 其它內(nèi)存同步主內(nèi)存到工作內(nèi)存
- 然后從工作內(nèi)存中讀取
一個線程寫入后,不能保證其它線程立即看到,這就是可見性問題。
加了volatile關(guān)鍵字后,會強(qiáng)制操作后同步工作內(nèi)存和主內(nèi)存,保證其它線程立刻看到。