在 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中文網其他相關文章!