>Java >java지도 시간 >Java에서 `i`가 Atomic이 아닌 이유는 무엇입니까?

Java에서 `i`가 Atomic이 아닌 이유는 무엇입니까?

DDD
DDD원래의
2024-11-26 14:48:11483검색

Why Isn't `i  ` Atomic in Java?

Java에서 i가 Atomic이 아닌 이유는 무엇입니까?

Java에서 i 연산자는 원자적이지 않습니다. 즉, 두 스레드가 동시에 동일한 변수를 증가시키려고 하면 결과가 정확하지 않을 수 있습니다. 이는 i 작업이 세 가지 개별 단계로 구성되기 때문입니다.

  1. 변수의 현재 값 읽기
  2. 값 증가
  3. 새 값을 다시 변수에 쓰기 변수

두 스레드가 이 단계를 동시에 실행하는 경우 한 스레드가 다른 스레드보다 먼저 값을 읽을 가능성이 있습니다. 스레드가 이를 증가시켰습니다. 이로 인해 데이터가 손상될 수 있습니다.

예를 들어 다음 코드를 고려해 보세요.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.