java停止線程池中的線程 atomiclong怎么實(shí)現(xiàn)線程安全?
atomiclong怎么實(shí)現(xiàn)線程安全?Atomiclong是線程安全的,因?yàn)樗褂脴酚^鎖。不安全是指做一些Java語言不允許但非常有用的事情。具體實(shí)現(xiàn)是原生方法。atomicinteger中調(diào)用的不安
atomiclong怎么實(shí)現(xiàn)線程安全?
Atomiclong是線程安全的,因?yàn)樗褂脴酚^鎖。
不安全是指做一些Java語言不允許但非常有用的事情。具體實(shí)現(xiàn)是原生方法。atomicinteger中調(diào)用的不安全方法基于CPU的CAS指令。因此,基于CAS的操作可以被認(rèn)為是非阻塞的,一個(gè)線程的失敗或掛起不會(huì)導(dǎo)致其他線程的失敗或掛起。而且由于CAS操作是CPU原始操作,因此具有更好的性能。
多個(gè)線程可以讀一個(gè)變量,只有一個(gè)線程可以對這個(gè)變量進(jìn)行寫,到底要不要加鎖?
下面簡要說明以下原因:
鎖定是因?yàn)椴僮鞑皇窃拥摹W屛覀冇貌僮饕粊斫忉屗???聪旅鎯蓚€(gè)圖。
我這個(gè)操作需要
看上面的第二個(gè)圖,你能很清楚地理解這個(gè)過程嗎?
鎖定是為了確保上述三個(gè)步驟是原子操作。
回到問題上來,只有一個(gè)線程要寫,沒有競爭,所以不需要鎖定。
但是,如果你看第一張圖片,因?yàn)橹鲀?nèi)存和本地內(nèi)存的存在
在一個(gè)線程寫入后,其他線程無法立即看到它。這就是可見性問題。
添加volatile關(guān)鍵字后,它將在操作后強(qiáng)制工作內(nèi)存和主內(nèi)存同步,以確保其他線程可以立即看到它。