인프런 커뮤니티 질문&답변

Luvel님의 프로필 이미지
Luvel

작성한 질문수

김영한의 실전 자바 - 고급 1편, 멀티스레드와 동시성

Object - wait, notify - 한계

스레드 기아상태 - 모든 스레드가 wait인 상황

작성

·

130

0

안녕하세요 영한님
바로 아래 질문에서 조금 더 의문이 있어 질문드립니다.

image.png


4분대 그림에서 c0 소비자 스레드는 데이터를 얻고 notify()해서 스레드 대기 집합에 있는 임의의 스레드를 깨울 것입니다.

만일 이때 소비자 스레드 c1이 깨어나면, 큐에 소비할 데이터가 없어서 다시 스레드 대기 집합으로 들어갈텐데,
그 다음은 notify()를 호출할 스레드가 없어서 모든 스레드가 WAITING 상태로 대기 집합에 있을 것으로 생각합니다.

 

그러면 이후 다른 새로 생성된 생산자 스레드가 put()을 호출하지 않는한 모든 스레드가 쉬고 있는 상황에 놓이는게 맞을까요?

결국에는 p1을 깨우지 않는 스레드 기아 상태는 이해되는데,
교안에 "최악의 경우 c1 ~ c5 스레드가 반복해서 깨어날 수 있다." 표현에서 스레드들이 계속 연쇄적으로 깨어나는 뉘앙스가 느껴져서 명확히 하고자 여쭤봅니다.

답변 2

2

안녕하세요 Luvel님, 공식 서포터즈 코즈위버입니다.

이해하신 내용이 맞습니다. 현재 예제 코드에서는 데이터가 비어있을 경우 소비자는 wait() 상태로 전환되며 별도로 notify()를 호출하지 않습니다. 그래서 말씀하신것처럼 c0이 데이터를 소비하고 notify()를 호출하였을 때 c1이 꺠어났다면 c1은 바로 wait() 상태에 빠지게 되며 이후에는 누군가 notify()를 호출하기 전까지 모두 대기 상태가 됩니다.

 

강의에서 상정한 최악의 상황은 Object.notify() 는 대기중인 큐를 랜덤으로 깨우기에 말씀하신 상황처럼 모든 큐가 대기상황에 빠졌을때 외부에서 강제로 notify()를 호출한다 하더라도 계속해서 소비자 스레드만 깨어나는 문제가 생길 수 있음을 설명한 것입니다.

감사합니다.

Luvel님의 프로필 이미지
Luvel
질문자

덕분에 헷갈리던 부분이 잘 해소되었습니다
명쾌한 답변 감사드립니다!
좋은 하루되세요 😀

-1

안녕하세요, 인프런 AI 인턴입니다.

Luvel님의 질문은 스레드 기아상태와 관련된, 모든 스레드가 WAITING 상태로 대기하는 상황에 대해 깊이 있는 질문으로 보입니다. 직접적인 답변이 가능한 내용이 있어 해당 정보를 제공해드리겠습니다.

유사한 상황에 대해 김영한 강사님께서 답변하신 모든 스레드가 wait 상태 질문이 있습니다. 이 답변에서는 스레드가 wait 상태로 들어가는 상황과 그 관리에 대해 설명하고 있습니다.

이 질문에서는 c0 스레드가 큐에서 데이터를 소비한 후 wait 상태로 들어갔을 때, notify를 호출하지 않기 때문에 모든 스레드가 wait 상태에 들어갈 수 있는지에 대한 문제를 제기합니다. 강사님은 c0가 데이터를 성공적으로 소비한 후의 상황에 대해 설명하시며, 여기서 notify 호출의 필요성과 관리 방법에 대해 설명하고 있습니다.

Luvel님의 질문에 대해, 스레드 기아상태와 연속적으로 스레드가 깨어나는 상황은 동시성 프로그래밍에서 중요한 이슈 중 하나입니다. 강사님의 설명을 통해 이해할 수 있는 부분은, 조건을 충족시킬 때까지 스레드가 반복해서 깨어날 수 있고, 이를 관리하기 위한 메커니즘(예: notifyAll 사용, 적절한 조건 체크 로직 구현 등)의 중요성이 강조됩니다.

강사님의 답변은 주로 스레드가 데이터를 소비한 후의 상황과 notify 사용에 초점을 맞추고 있으니, Luvel님의 궁금증을 해소하는 데 도움이 될 것으로 생각됩니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

Luvel님의 프로필 이미지
Luvel

작성한 질문수

질문하기