JAVA原子类AtomicInteger源码阅读笔记
最近在为春招实习复习,所以也看了些java并发包的源码,打算记个笔记。
首先展示一些 AtomicInteger里持有的属性。
private static final long serialVersionUID = 6214790243416807050L;
private static final Unsafe U = Unsafe.getUnsafe();
private static final long VALUE;
private volatile int value;
VALUE即当前类里value偏移量offset,将由静态代码进行初始化:
static {
VALUE = U.objectFieldOffset(AtomicInteger.class, "value");
}
Unsafe可以理解为用于原子操作的一个工具类。在 Unsafe类中持有一个静态final实例,每次调用getUnsafe()方法时都将返回该实例。
接下来以getAndAdd方法为例看看具体是如何执行的:
public final int getAndAdd(int delta) {
return U.getAndAddInt(this, VALUE, delta);
}
可见将由Unsafe实例进行实际操作,传入的是当前实例,偏移量和将要加的数值。
以下是Unsafe内的具体方法操作:
@HotSpotIntrinsicCandidate
public final int getAndAddInt(Object o, long offset, int delta) {
int v;
do {
v = this.getIntVolatile(o, offset);
} while(!this.weakCompareAndSetInt(o, offset, v, v + delta));
return v;
}
逻辑梳理:
首先根据对象和偏移量从内存中获得当前value值(所以value是volatile的)即expected。
接着会执行原子操作CAS,若返回True说明执行原子操作时根据o和offset获得的v值和之前获取的v值(expected)一致,可以成功执行,此时返回执行后的结果:否则说明执行CAS时value被其他线程修改,此时执行失败,while循环判断不通过,自旋再次尝试执行。
以上
本文深入剖析了JAVA并发包中的AtomicInteger源码,详细解读了其内部属性与工作原理,特别是getAndAdd方法的实现过程,揭示了Unsafe类在原子操作中的作用。
5741

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



