Atomic类是通过Unsafe类,实现的原子性。而Unsafe类是由native方法实现的。
看下源码:
public class AtomicInteger extends Number implements java.io.Serializable {
public final int getAndIncrement() {
return unsafe.getAndAddInt(this, valueOffset, 1);
}
}
Unsafe类
public final int getAndAddInt(Object var1, long var2, int var4) {
int var5;
do {
var5 = this.getIntVolatile(var1, var2);
} while(!this.compareAndSwapInt(var1, var2, var5, var5 + var4));
return var5;
}
我们看到是通过CAS加循环实现的。
CAS有什么问题?
1.会产生ABA的问题
2.并发高的时候,大部分线程都在频繁轮询,导致CPU开销很大。
3.不保证多个变量的原子性

Atomic类通过Unsafe类实现原子操作,Unsafe由native方法实现。AtomicInteger的getAndIncrement方法通过Unsafe的getAndAddInt实现,使用CAS加循环确保原子性。然而,CAS存在ABA问题和高并发下的CPU开销问题。
1280

被折叠的 条评论
为什么被折叠?



