一.i++
i++的操作分三步:
(1)栈中取出i
(2)i自增1
(3)将i存到栈
所以i++不是原子操作,上面的三个步骤中任何一个步骤同时操作,都可能导致i的值不正确自增
二.++i
在多核的机器上,cpu在读取内存i时也会可能发生同时读取到同一值,这就导致两次自增,实际只增加了一次。
综上,我认为i++和++i都不是原子操作。
三、确保原子性
1、加锁
2、为了保证其原子性,可以使用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是通过硬件命令保证了原子性。