为什么 i 在 Java 中不是原子的?
在 Java 中,i 运算符不是原子的,这意味着如果两个线程尝试同时递增同一个变量,结果可能不正确。这是因为 i 操作由三个独立的步骤组成:
- 读取变量的当前值
- 增加值
- 将新值写回变量
如果两个线程同时执行这些步骤,则一个线程可能会先于另一个线程读取该值线程已增加它。这可能会导致数据损坏。
例如,考虑以下代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | class Test {
private static int total = 0;
public static void main(String[] args) {
Thread thread1 = new Thread( new Runnable() {
@Override
public void run() {
for (int i = 0; i < 100000; i++) {
total++;
}
}
});
Thread thread2 = new Thread( new Runnable() {
@Override
public void run() {
for (int i = 0; i < 100000; i++) {
total++;
}
}
});
thread1.start();
thread2.start();
thread1.join();
thread2.join();
System.out.println( "Total: " + total);
}
}
|
登录后复制
运行此代码时,预计会打印 200000,但实际上可能会打印更低的值由于 i 运算符的非原子性质,值。
为了确保多线程代码原子地访问共享变量,有必要使用同步机制,例如锁或原子变量。 Synchronized 关键字可用于同步对代码块的访问,而 AtomicInteger 类提供原子整数类型。
以上是为什么 Java 中的 i 不是原子的?的详细内容。更多信息请关注PHP中文网其他相关文章!