◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
i++ 的原子性探讨
在软件开发中,原子性操作是指不可中断的基本操作序列。那么,一个常见的操作符 i++ 是否是一个原子操作呢?
答案:否
i++ 并不是一个原子操作,它实际上是一种语法糖。为了实现 i++ 的功能,编译器会将其转换为三个顺序执行的动作:
这三个动作并不是同时执行的,因此 i++ 并不是一个原子操作。以下代码演示了这一点:
int i = 0; Thread t1 = new Thread(() -> { for (int j = 0; j < 100000; j++) { i++; } }); Thread t2 = new Thread(() -> { for (int j = 0; j < 100000; j++) { i++; } }); t1.start(); t2.start(); t1.join(); t2.join(); System.out.println(i); // 输出可能小于 200000
如果 i++ 是一个原子操作,那么最终输出应该是 200000。然而,由于非原子性,两个线程可能会交替执行 i++ 的三个动作,导致最终值低于预期结果。
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。