Executor 스레드 작업 처리 질문
70
작성한 질문수 1
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
스레드 풀과 Executor 프레임워크 강의1, 2를 듣고 공부하던 중에
task가 <큐에 담긴 후 | 큐에 담기지 않고> 스레드가 작업을 처리하는 것의 기준을 정확히 이해했는지 궁금하여 질문드립니다.
12강 CallableMainV2 예제의 실행 결과 분석에서
executorService에 taskA 작업을 submit()으로 요청하면,
"Future 가 만들어지고, taskA 를 감싸고 있는 Future 가 블로킹 큐에 담긴 후에 큐에 들어있는 Future[taskA] 를 꺼내서 스레드 풀의 스레드1이 작업을 시작한다고 하셨습니다."
13강의 PoolSizeMainV1 예제의 실행 결과 분석에서는 task1 작업 요청을 하면
"작업을 처리하기 위해 스레드를 하나 생성했기 때문에 작업을 큐에 넣을 필요 없이, 해당 스레드가 바로 작업을 처리한다." 라고 하셨습니다.
12강 예제에서는 요청을 받기 전에 WAITING 상태의 스레드가 존재하였고, 작업을 수행하기 위해서는 WAITING 상태의 스레드를 깨워야하기 때문에 블로킹 큐에 task가 담겨야 하고,
13강 예제에서는 task 요청이 오자 task를 수행하기 위한 새로운 스레드가 생성되었고, 스레드를 깨우지 않아도 바로 task를 실행할 수 있기 때문에 블로킹 큐에 넣을 필요가 없다
이렇게 이해하면 되는지 궁금합니다!
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. ferrater1013님.
스레드 풀과 Executor 프레임워크에 대한 질문에 대해 설명드리겠습니다.
Java의 Executor 서비스는 작업을 효율적으로 관리하기 위해 스레드 풀을 사용하며, 각 작업은 블로킹 큐를 거쳐 스레드가 처리하게 됩니다. 이를 통해 시스템의 리소스를 효율적으로 사용할 수 있습니다. 각 예제에서 다루는 스레드 처리 방식은 스레드 풀의 구성과 실행 상황에 따라 약간 다르게 진행될 수 있습니다.
12강
CallableMainV2예제:- 이 예제에서는 기본적으로
ExecutorService가 생성한 스레드가 WAITING 상태로 대기하고 있습니다. 작업이 submit()되어 Future로 래핑되면, 이 Future 객체는 스레드 풀의 블로킹 큐에 추가됩니다. 스레드 풀 내에서 대기 중인 스레드는 블로킹 큐에서 새로운 작업을 가져와 자동적으로 작업을 수행하게 됩니다. 즉, WAITING 상태의 스레드를 깨워 작업하기 때문에 작업이 큐에 담깁니다.
- 이 예제에서는 기본적으로
13강
PoolSizeMainV1예제:- 이 예제에서는 새로운 스레드를 즉시 생성하여 작업을 처리합니다. 이는 주어진 스레드 풀 크기 및 현재 스레드의 사용 상태에 따라 결정됩니다. 만약 스레드를 추가적으로 생성할 수 있는 여유가 있다면, 새로 요청된 작업은 즉시 처리될 수 있으며, 큐에 담길 필요가 없습니다. 즉, 스레드를 깨우지 않아도 작업이 즉시 처리되기 때문에 큐에 넣을 필요가 없습니다.
- 이 예제에서는 새로운 스레드를 즉시 생성하여 작업을 처리합니다. 이는 주어진 스레드 풀 크기 및 현재 스레드의 사용 상태에 따라 결정됩니다. 만약 스레드를 추가적으로 생성할 수 있는 여유가 있다면, 새로 요청된 작업은 즉시 처리될 수 있으며, 큐에 담길 필요가 없습니다. 즉, 스레드를 깨우지 않아도 작업이 즉시 처리되기 때문에 큐에 넣을 필요가 없습니다.
결론적으로, 각 예제에서 다루는 방식은 스레드 풀의 상태 및 설정에 따라 작업이 블로킹 큐에 넣어지는지, 아니면 즉시 처리되는지가 결정된다고 이해하시면 됩니다.
또한, 이전에 답변된 유사한 질문과 스레드풀 관리에 대한 추가 답변도 있으니, 참고하시어 더 나은 이해를 돕기 바랍니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
모니터와 synchronized, ReentrantLock, 원자적연산 CAS관련해서 추가적으로 더 깊게 공부했는데 제가 이해한 것이 맞나요??
0
84
1
Future cancel기능을 사용했지만 interrupt가 발생하지 않을 때 어떻게 처리해야하나요?
0
72
2
2.스레드 생성과 실행 - 17P 그림 문의
0
73
2
자바 동시성 현업에서 사용예시가 궁금합니다
0
133
1
ReentrantLock 동작 원리에 대한 질문입니다.
0
81
1
synchronized 대신 join 을 사용하여 순서를 보장할 경우 해법이 아닌가요?
0
93
2
메모리 가시성 문제 질문
0
69
1
Future4-이유 질문
0
64
1
오타 제보
0
74
2
runnable 질문
0
95
2
자바가 아닌 다른 언어에서도
0
111
1
메모리 가시성 문제가 발생하는 이유
0
125
1
데몬스레드가 어떨 때 사용이 되는지 궁금합니다.
0
78
1
Future.cancel() 취소를 사용하는 예가 궁금합니다.
0
84
1
synchronized 와 인스턴스의 lock
0
90
2
synchronized 키워드만으로 메모리 가시성이 해결되는 이유가 궁급합니다.
0
62
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
82
2
교안에 있는 7페이지 데이터 영역
0
51
1
Executor 스레드 풀 관리 질문
0
108
2





