如何深入理解Java多線程與并發(fā)框中的CAS,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
CAS 是 CompareAndSwap 的縮寫,意思是 比較 并 交換。 它是無鎖化的實(shí)現(xiàn)是經(jīng)典的樂觀鎖。
CAS 操作很簡單,它包含三個操作數(shù):內(nèi)存地址V、預(yù)期原值A(chǔ)、新值B。先比較內(nèi)存地址V處的值與預(yù)期原值A(chǔ)是否相等,如果相等就將內(nèi)存地址V處更新為新值B。在配合循環(huán)使用時,若CAS操作失敗,會循環(huán)執(zhí)行或到達(dá)某個終止處。此操作配合 循環(huán) 使用時,又稱為 自旋鎖 的實(shí)現(xiàn)方式。
1. ABA的問題
比如一個線程操作時,先將內(nèi)存地址V處的值A(chǔ)更新為值B,然后又將值B更新為值A(chǔ)。最后CAS判斷內(nèi)存地址V處的沒有變化,認(rèn)為操作更新未成功,但實(shí)質(zhì)上是已經(jīng)更新過了。這就是經(jīng)典的 ABA問題。
解決方法:
加時間戳:
加版本號:
2. 循環(huán)開銷大
CAS 這種也是樂觀鎖,如果線程較多、資源搶占激烈、命中率低的情況下,不斷的循環(huán)會不斷的消耗資源。實(shí)現(xiàn)上,可以設(shè)置大循環(huán)數(shù),達(dá)到大循環(huán)數(shù)還沒有占有資源就自動放棄,避免無限的循環(huán)。
3. 最多只能保證一個共享變量的操作
CAS 最多只能操作一個共享變量,單體效率低。
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。
網(wǎng)站題目:如何深入理解Java多線程與并發(fā)框中的CAS-創(chuàng)新互聯(lián)
分享網(wǎng)址:http://www.rwnh.cn/article28/csogcp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、建站公司、關(guān)鍵詞優(yōu)化、網(wǎng)站建設(shè)、網(wǎng)站改版、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容