1,原子類介紹:
針對數據類型的操作,JDK提供的原子類來方便我們的線程安全控制。
所有的類保存在 java.util.concurrent.atomic 包中
基本數據類型 AtomicInteger
數組類型 AtomicIntegerArray
2,舉個使用的例子:
解決之前的 i++ 安全性問題
如何解決?
AtomicInteger count = new AtomicInteger(0);
count.incrementAndGet();//相當於count++,區別是這裏可以保證是原子操作
3,原理:
內部的原理是採用了CAS機制,大家可以通過觀察源碼就可以發現
那麼什麼是CAS機制?
CAS有人翻譯爲Compare And Set或Compare And Swap都是正確的。
在多線程併發執行的狀態下,鎖的狀態改變,基本都是使用CAS原理,它有一個比較彆扭的叫法“CPU硬件同步原語”,算法是基於CPU硬件的,原子性操作,不會被其他線程打斷。
CAS的算法,比較當前值和期望的值是否相等,如果相等,則將當前值賦予一個新值。
再比如修改一個Boolean的類型的變量的值,我們也可以採用
private AtomicBoolean atomicBoolean = new AtomicBoolean(false);
public void lock(){
//期望是false,如果是false,則可以修改爲true
atomicBoolean.compareAndSet(false, true);
}