> Java > java지도 시간 > Java의 동기화된 블록 내에서 `wait()`를 호출해야 하는 이유는 무엇입니까?

Java의 동기화된 블록 내에서 `wait()`를 호출해야 하는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2024-12-09 07:05:11
원래의
770명이 탐색했습니다.

Why Must `wait()` Be Called Inside a Synchronized Block in Java?

wait()가 동기화된 블록 내에 있어야 하는 이유

동기화된 블록 내에서 Object.wait() 호출을 강제하는 것은 중요한 역할을 합니다. Java 동시성 모델의 목적. 이 제한 사항을 준수하지 않으면 IllegalMonitorStateException이 발생하지만 이 제한 사항의 근거를 이해하는 것이 중요합니다.

Synchronized Wait()의 이유

wait()는 동기화된 개체와 연결된 모니터입니다. wait()를 호출하기 전에 모니터를 명시적으로 획득하면 대기 작업이 발생할 때 호출 스레드가 모니터를 독점적으로 보유하게 됩니다. 이렇게 하면 호출 스레드가 기다리는 동안 다른 스레드가 공유 상태를 수정할 수 없습니다.

동기화된 블록 외부의 Wait() 결과

wait()가 동기화된 블록 외부에서 호출하면 다양한 문제가 발생할 수 있습니다. 다음 시나리오를 고려하십시오.

예: 차단 대기열

소비자 스레드가 대기열에서 요소를 가져오고 생산자 스레드가 요소를 추가하도록 허용하는 차단 대기열을 상상해 보세요. 대기열에. 동기화 없음:

class BlockingQueue {
    Queue<String> buffer = new LinkedList<>();

    void take() throws InterruptedException {
        while (buffer.isEmpty()) {
            // Suspend thread without acquiring the monitor
            wait();
        }
    }
}
로그인 후 복사

잠재적 문제:

  • 경합 조건: 생산자 스레드는 버퍼에 요소를 추가할 수 있지만 소비자 스레드는 다음과 같은 이유로 inform() 호출을 놓칠 수 있습니다. 이미 wait()에 진입했습니다.
  • 교착 상태: 생산자 스레드는 빈 버퍼를 기다리면서 차단될 수 있으며 소비자 스레드는 오류로 인해 일시 중지된 상태로 유지됩니다. unnoticed inform().

범용 동기화 요구 사항

이 동기화 문제는 차단 대기열 예시에만 국한되지 않습니다. wait() 및 inform()을 사용하는 스레드 통신과 관련된 모든 시나리오에는 경합 조건 및 잠재적인 교착 상태를 방지하기 위해 동기화가 필요합니다.

Waiter와 Notifier 간의 합의

동기화된 wait() 대기자 스레드(소비)와 알림 스레드(생성)가 공유 리소스(술어)의 상태에 동의하는지 확인합니다. 이 계약은 웨이터가 기다리기 전에 조건자를 올바르게 확인하고 취약한 기간 동안 알림을 놓치지 않도록 보장합니다.

위 예에서 조건자는 buffer.isEmpty()입니다. 동기화를 통해 소비자 스레드는 버퍼가 실제로 비어 있을 때만 일시 중단됩니다.

위 내용은 Java의 동기화된 블록 내에서 `wait()`를 호출해야 하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿