在学习原子操作的时候,遇到了自增的方法,但发现AtomicInteger类中有两个类似的方法,研究了下,做下笔记记录。
首先看下两个方法的源码:
public final int getAndIncrement() {
return unsafe.getAndAddInt(this, valueOffset, 1);
}
public final int incrementAndGet() {
return unsafe.getAndAddInt(this, valueOffset, 1) + 1;
}
可以看到,两者都是调用了unsafe的getAndAddInt方法,只是后面的进行了加1操作。
我们看一下unsafe的getAndAddInt方法返回的是什么。
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;
}
getAndAddInt方法这个源码,就是经典的CAS自旋操作Volatile变量,不了解的可以去百度,这个方法会不停的循环的判断当前的值是否没有被修改,如果没有被修改,就进行加法操作,这里就是进行了加1的操作。注意,这里返回的var5是加法之前的结果,因此相信聪明的你已经知道了,这个方法返回的是加1之前的结果,那么上述两个方法区别就是一个返回加1之前的结果,一个返回加1之后的结果。