i++是原子操作吗?怎么保证其原子性
i++不是原子操作,因为有多个步骤,为了保证其原子性,可以使用AtomicInteger类的getAndIncrement()方法实现i++
我们先来看一下getAndIncrement的源代码:
* public final int getAndIncrement() {
* for (;;) {
* int current = get(); // 取得AtomicInteger里存储的数值
* int next = current + 1; // 加1
* if (compareAndSet(current, next)) // 调用compareAndSet执行原子更新操作
* return current;
* }
* }
其核心原理是CAS(compareAndSwap)原理
通过内存值V 预期值A 更新值B 先对v和A进行比较 如果相等 则将v更新为B 如果不相等则不更新。
CAS的操作虽然也是多个步骤,但CAS是通过硬件命令保证了原子性。