如何深入理解Java多線程與并發(fā)框中的CAS,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
貴州網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián),貴州網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為貴州超過(guò)千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)公司要多少錢(qián),請(qǐng)找那個(gè)售后服務(wù)好的貴州做網(wǎng)站的公司定做!
CAS 是 CompareAndSwap 的縮寫(xiě),意思是 比較 并 交換。 它是無(wú)鎖化的實(shí)現(xiàn)是經(jīng)典的樂(lè)觀鎖。
CAS 操作很簡(jiǎn)單,它包含三個(gè)操作數(shù):內(nèi)存地址V、預(yù)期原值A(chǔ)、新值B。先比較內(nèi)存地址V處的值與預(yù)期原值A(chǔ)是否相等,如果相等就將內(nèi)存地址V處更新為新值B。在配合循環(huán)使用時(shí),若CAS操作失敗,會(huì)循環(huán)執(zhí)行或到達(dá)某個(gè)終止處。此操作配合 循環(huán) 使用時(shí),又稱為 自旋鎖 的實(shí)現(xiàn)方式。
1. ABA的問(wèn)題
比如一個(gè)線程操作時(shí),先將內(nèi)存地址V處的值A(chǔ)更新為值B,然后又將值B更新為值A(chǔ)。最后CAS判斷內(nèi)存地址V處的沒(méi)有變化,認(rèn)為操作更新未成功,但實(shí)質(zhì)上是已經(jīng)更新過(guò)了。這就是經(jīng)典的 ABA問(wèn)題。
解決方法:
加時(shí)間戳:
加版本號(hào):
2. 循環(huán)開(kāi)銷大
CAS 這種也是樂(lè)觀鎖,如果線程較多、資源搶占激烈、命中率低的情況下,不斷的循環(huán)會(huì)不斷的消耗資源。實(shí)現(xiàn)上,可以設(shè)置最大循環(huán)數(shù),達(dá)到最大循環(huán)數(shù)還沒(méi)有占有資源就自動(dòng)放棄,避免無(wú)限的循環(huán)。
3. 最多只能保證一個(gè)共享變量的操作
CAS 最多只能操作一個(gè)共享變量,單體效率低。
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。