描述
? ??????CAS(Compare And Swap)就是樂(lè)觀鎖機(jī)制。加鎖就是原子操作,原子操作就是類似于事務(wù),syn就是原子操作。
原理
? ??????利用現(xiàn)代處理器的CAS指令,循環(huán)這個(gè)指令,直到成功為止。
CAS問(wèn)題
? ??????1、ABA問(wèn)題:根據(jù)版本號(hào)可以解決。
? ? ? ? 2、開(kāi)銷問(wèn)題:因?yàn)榭赡懿粩嘌h(huán)計(jì)算,所以比較消耗cpu性能
? ? ? ? 3、只能保證一個(gè)共享變量的原子操作
Jdk中相關(guān)原子操作類的使用
????????(1) 更新基本類型類:AtomicBoolean,AtomicInteger,AtomicLong;
????????(2) 更新數(shù)組類:AtomicIntegerArray,AtomicLongArray,AtomicReferenceArray;
????????(3)更新引用類型類:AtomicReference(可以解決只能有一個(gè)共享變量的問(wèn)題),AtomicMarkableReference(會(huì)記錄是否變化,可以解決ABA問(wèn)題),AtomicStampedReference(會(huì)記錄變化的次數(shù),可以解決ABA問(wèn)題);
????????(4) 原子更新字段類:AtomicReferenceFieldUpdater(更新某個(gè)類中的某個(gè)字段),AtomicIntegerFieldUpdater,AtomicLongFieldUpdater。
? ??????Atomic原理:Atomic操作數(shù)組實(shí)際上更改數(shù)據(jù)后是新建了一個(gè)數(shù)組而不會(huì)操作原來(lái)的數(shù)組。使用AtomicReference可以解決只能修改一個(gè)變量的問(wèn)題。
? ??????