在 Java 中,i 运算符不是原子的,这意味着如果两个线程尝试同时递增同一个变量,结果可能不正确。这是因为 i 操作由三个独立的步骤组成:
如果两个线程同时执行这些步骤,则一个线程可能会先于另一个线程读取该值线程已增加它。这可能会导致数据损坏。
例如,考虑以下代码:
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中文网其他相关文章!