您好,登錄后才能下訂單哦!
如何深入理解Java多線程與并發框中的CAS,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
CAS 是 CompareAndSwap 的縮寫,意思是 比較 并 交換。 它是無鎖化的實現是經典的樂觀鎖。
CAS 操作很簡單,它包含三個操作數:內存地址V、預期原值A、新值B。先比較內存地址V處的值與預期原值A是否相等,如果相等就將內存地址V處更新為新值B。在配合循環使用時,若CAS操作失敗,會循環執行或到達某個終止處。此操作配合 循環 使用時,又稱為 自旋鎖 的實現方式。
1. ABA的問題
比如一個線程操作時,先將內存地址V處的值A更新為值B,然后又將值B更新為值A。最后CAS判斷內存地址V處的沒有變化,認為操作更新未成功,但實質上是已經更新過了。這就是經典的 ABA問題。
解決方法:
加時間戳:
加版本號:
2. 循環開銷大
CAS 這種也是樂觀鎖,如果線程較多、資源搶占激烈、命中率低的情況下,不斷的循環會不斷的消耗資源。實現上,可以設置最大循環數,達到最大循環數還沒有占有資源就自動放棄,避免無限的循環。
3. 最多只能保證一個共享變量的操作
CAS 最多只能操作一個共享變量,單體效率低。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。