高併發編程-07-JDK提供的原子類操作及原理

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);

}



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章