深入理解Java多執行緒與併發框(第⑧篇)——深入理解:CAS
CAS實現原理
CAS 是 CompareAndSwap 的縮寫,意思是 比較 並 交換。 它是無鎖化的實現是經典的樂觀鎖。
CAS 操作很簡單,它包含三個運算元:記憶體地址V、預期原值A、新值B。先比較記憶體地址V處的值與預期原值A是否相等,如果相等就將記憶體地址V處更新為新值B。在配合迴圈使用時,若CAS操作失敗,會迴圈執行或到達某個終止處。此操作配合 迴圈 使用時,又稱為 自旋鎖 的實現方式。
CAS存在的問題
1. ABA的問題
比如一個執行緒操作時,先將記憶體地址V處的值A更新為值B,然後又將值B更新為值A。最後CAS判斷記憶體地址V處的沒有變化,認為操作更新未成功,但實質上是已經更新過了。這就是經典的 ABA問題。
解決方法:
- 加時間戳:
- 加版本號:
2. 迴圈開銷大
CAS 這種也是樂觀鎖,如果執行緒較多、資源搶佔激烈、命中率低的情況下,不斷的迴圈會不斷的消耗資源。實現上,可以設定最大迴圈數,達到最大迴圈數還沒有佔有資源就自動放棄,避免無限的迴圈。
3. 最多隻能保證一個共享變數的操作
CAS 最多隻能操作一個共享變數,單體效率低。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69964492/viewspace-2683157/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 深入理解Java多執行緒與併發框(第①篇)——執行緒的狀態Java執行緒
- 深入理解Java多執行緒與併發框(第⑪篇)——執行緒池引數Java執行緒
- 深入理解Java多執行緒與併發框(第⑦篇)——volatile 關鍵字Java執行緒
- 深入理解Java多執行緒與併發框(第④篇)——重排序、屏障指令、as-if-serial規則Java執行緒排序
- 深入理解Java多執行緒與併發框(第⑩篇)——併發輔助工具類(很好的玩的工具類)Java執行緒
- 深入理解Java多執行緒與併發框(完結篇)——看完再不懂多執行緒我跪鍵盤Java執行緒
- 深入理解Java多執行緒與併發框(第③篇)——Java記憶體模型與原子性、可見性、有序性Java執行緒記憶體模型
- Java併發程式設計——深入理解執行緒池Java程式設計執行緒
- 深入理解JVM(③)執行緒與Java的執行緒JVM執行緒Java
- 深入理解Flutter多執行緒Flutter執行緒
- 深入淺出Java多執行緒(十):CASJava執行緒
- 【高併發】深入理解執行緒的執行順序執行緒
- 深入理解多執行緒(二)—— Java的物件模型執行緒Java物件模型
- 深入理解多執行緒(三)—— Java的物件頭執行緒Java物件
- 深入理解執行緒池原理篇執行緒
- 深入理解多執行緒程式設計執行緒程式設計
- 深入Java原始碼理解執行緒池原理Java原始碼執行緒
- Java併發/多執行緒-CAS原理分析Java執行緒
- Java併發程式設計——深入理解執行緒間的協作方式Java程式設計執行緒
- 深入理解 Java 多執行緒、Lambda 表示式及執行緒安全最佳實踐Java執行緒
- 深入理解執行緒通訊執行緒
- Java核心(二)深入理解執行緒池ThreadPoolJava執行緒thread
- [深入理解Java虛擬機器]執行緒Java虛擬機執行緒
- 深入理解執行緒池的執行流程執行緒
- 深入理解併發和並行並行
- 深入理解多執行緒(一)——Synchronized的實現原理執行緒synchronized
- 深入淺出Java多執行緒Java執行緒
- 深入理解JVM(③)再談執行緒安全JVM執行緒
- 深入理解 OpenMP 執行緒同步機制執行緒
- 【Mysql】深入理解 MVCC 多版本併發控制MySqlMVC
- 深入理解java:執行緒本地變數 java.lang.ThreadLocal類Java執行緒變數thread
- java多執行緒之volatile理解Java執行緒
- 深入淺出Java多執行緒(十二):執行緒池Java執行緒
- 2018跳槽面試必備之深入理解 Java 多執行緒核心知識面試Java執行緒
- java多執行緒與併發 - 併發工具類Java執行緒
- Java併發程式設計,深入理解ReentrantLockJava程式設計ReentrantLock
- Java併發工具類:深入理解Concurrent包Java
- java多執行緒與併發 - 執行緒池詳解Java執行緒