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 연산자의 비원자적 특성으로 인해 값이 발생합니다.
멀티 스레드 코드가 공유 변수에 원자적으로 액세스하도록 하려면 다음이 필요합니다. 잠금이나 원자 변수와 같은 동기화 메커니즘을 사용합니다. 동기화된 키워드는 코드 블록에 대한 액세스를 동기화하는 데 사용할 수 있으며 AtomicInteger 클래스는 원자 정수 유형을 제공합니다.
위 내용은 Java에서 `i`가 Atomic이 아닌 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!