notify() 호출 후의 상황에 대해 질문 있습니다.
197
작성한 질문수 92
@Override
public synchronized void put(String data) {
while (queue.size() == max) {
log("[put] 큐가 가득 참, 생산자 대기");
try {
wait(); // RUNNABLE -> WAITING, 락 반납
log("[put] 생산자 깨어남");
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
}
queue.offer(data);
log("[put] 생산자 데이터 저장, notify() 호출");
notify(); // 대기 스레드, WAIT -> BLOCKED
}생산자 스레드가 먼저 실행되면 마지막 스레드는 wait() 호출 후 스레드 대기 집합에서 관리 되는걸로 이해했습니다.
이 상태에서 소비자 스레드가 실행되면 데이터를 처리하고 마지막에 notify()를 호출하면 스레드 대기 집합에서 관리 되던 생산자 스레드가 깨어날텐대 여기서 wait(); 바로 다음 코드를 실행하지 않고 바로 BLOCKED 상태가 되는건가요?
BLOCKED 상태에 있다가 소비자 스레드가 락을 반납 했을때 BLOCKED 상태가 풀리면서 wait() 바로 다음 코드를 실행한다고 이해하면 될까요?
답변 2
0
안녕하세요. 감바스님, 공식 서포터즈 코즈위버입니다.
2번 내용이 맞습니다. 생산자 스레드가 wait()을 만나면 그 지점에서 바로 대기하게 되고, 이후 notify() 에 의해 깨어나면 멈췄던 바로 그 지점의 다음줄 (예시에서는 log("[put] 생산자 꺠어남"); 이 실행됩니다.
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다.
감바스님의 질문은 notify() 호출 후의 상태 변화와 스레드의 상태 전이에 관한 것입니다. 이에 대해 명확한 답변을 드리겠습니다.
관련된 질문과 답변 링크를 아래에 제공드리겠습니다:
- 실전 자바 - 스레드 상태 설명: 이 질문에서는 스레드가
wait()후 상태 변화와notify()에 의해 깨어나는 메커니즘에 대해 설명하고 있습니다. 스레드가notify()에 의해 깨어났을 때 실제로 어떤 상태 변화를 겪는지, 즉BLOCKED상태가 되는지에 대해 살펴보실 수 있습니다.
답변을 요약하면, notify()에 의해 깨어난 스레드는 WAITING 상태에서 BLOCKED 상태로 변경됩니다. 여기서 BLOCKED 상태는 락을 취득하지 못했기 때문에 발생하는 상태입니다. 정확히 말씀드리면:
WAITING에서BLOCKED로 전이:notify()가 호출되면WAITING상태에 있던 스레드는 락을 취득하려고 시도하면서BLOCKED상태로 전이됩니다.락을 취득 후
RUNNABLE상태로 전이: 소비자 스레드가 락을 반납하게 되면,BLOCKED상태에 있는 스레드 중 하나가 락을 취득하면서RUNNABLE상태가 됩니다. 그러면 다시 실행 대기 큐에 들어가 실행을 준비하게 됩니다.wait()이후 코드 실행: 락을 취득한 후,wait()이후의 코드를 계속해서 실행하게 됩니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
모니터와 synchronized, ReentrantLock, 원자적연산 CAS관련해서 추가적으로 더 깊게 공부했는데 제가 이해한 것이 맞나요??
0
85
1
Future cancel기능을 사용했지만 interrupt가 발생하지 않을 때 어떻게 처리해야하나요?
0
73
2
2.스레드 생성과 실행 - 17P 그림 문의
0
74
2
자바 동시성 현업에서 사용예시가 궁금합니다
0
136
1
ReentrantLock 동작 원리에 대한 질문입니다.
0
83
1
synchronized 대신 join 을 사용하여 순서를 보장할 경우 해법이 아닌가요?
0
94
2
메모리 가시성 문제 질문
0
72
1
Future4-이유 질문
0
64
1
오타 제보
0
76
2
runnable 질문
0
95
2
자바가 아닌 다른 언어에서도
0
111
1
메모리 가시성 문제가 발생하는 이유
0
125
1
데몬스레드가 어떨 때 사용이 되는지 궁금합니다.
0
78
1
Future.cancel() 취소를 사용하는 예가 궁금합니다.
0
84
1
synchronized 와 인스턴스의 lock
0
91
2
synchronized 키워드만으로 메모리 가시성이 해결되는 이유가 궁급합니다.
0
63
1
[스레드 풀과 Executor 프레임워크1][문제와 풀이] `log("일부 작업이 실패했습니다.");` 실행되는 경우가 있을까요?
0
59
1
원자적 연산이 멀티스레드 상황에서 안전한 이유를 제대로 이해했는지 확인 부탁드립니다
0
67
2
자바 고급 1,2,3편 같이 진행해도 문제없나요
0
77
2
CPU 캐시 때문에도 잔액이 200원이 될 수 있나요?
0
105
2
synchronized 메서드와 join 관련 질문이 있습니다.
0
69
2
섹션 14. 115번 강의 내용 질문
0
83
2
교안에 있는 7페이지 데이터 영역
0
51
1
Executor 스레드 풀 관리 질문
0
108
2





