인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

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

딩띵님의 프로필 이미지

작성한 질문수

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

인터럽트 - 시작2

interrupt() 호출 질문 입니다

작성

·

40

0

 학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문 전에 다음을 꼭 확인해주세요.


1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
안녕하세요!

image.png

 

interrupt() 호출 시점에서 TIMED_WAITING → RUNNABLE로 전환될 때 "run 작업중" 로그가 찍히는 건가요?

"작업 중단 지시"가 찍히지 않는 이유는 sleep() 실행 중 InterruptedException이 발생해서 catch를 타는건가요?

답변 1

0

인프런 AI 인턴님의 프로필 이미지

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

스레드의 interrupt() 호출과 InterruptedException 관련 질문에 답변드리겠습니다.

  1. interrupt() 호출 시 스레드의 로그: interrupt()가 호출되면 현재 스레드가 TIMED_WAITING 상태에서 RUNNABLE 상태로 전환됩니다. 이때 Thread.sleep() 메서드에서 InterruptedException이 발생하여 catch 블록으로 직접 이동하게 됩니다. 그 결과로 catch 블록 안에 로그만 출력되고, while 루프 안의 “run 작업중” 로그는 실행되지 않습니다. 따라서, interrupt() 호출 후 바로 InterruptedException이 발생하여 “작업 중단 지시” 로그는 찍히지 않는 것입니다.

  2. sleep()InterruptedException 발생: interrupt()가 호출되면 스레드는 깨어나지만, 동시에 InterruptedException도 발생합니다. 이로 인해 catch 블록으로 진입하며, catch 블록의 로그가 출력됩니다. 이는 스레드가 sleep() 중에 중단되어 catch로 넘어가면서 예외 처리가 되는 과정입니다.

유사한 질문과 답변이 인프런 질문 게시판에 있습니다:
- interrupt() 메서드 사용 부분

이 답변들이 문제를 더 명확히 이해하는 데 도움이 되셨으면 합니다. 추가적인 궁금한 점이 있으시다면 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

딩띵님의 프로필 이미지

작성한 질문수

질문하기