futures 이해 및 GIL 에 대한 질문
284
3 asked
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
problem ) GIL -> 두 개 이상의 스레드가 동시에 실행 될 때 GIL 에 의해서 단일 스레드만 실행이됨.
멀티 스레드의 경우 문맥교환에 필요한 것을 고려하면 오히려 단일 스레드보다 성능이 떨어짐.
solution) concurrnet.futures 모듈을 사용해서 해결하고자함 .
processpoolexecutor 과 threadpoolexecutor 두 클래스를 사용해서 해결하는데
멀티스레드로 처리하느냐 혹은 멀티 프로세스를 처리하느냐의 차이인 것인데
q1 )멀티스레드로 처리하면 GIL에 결국 걸려야 하는 것 아닌가요 ??(GIL 에 걸리지 않게 멀티스레드를 사용하게 한 것이라면 어떻게 그렇게 만든 것 인지 궁금합니다)
q2)GIL 때문에 멀티스레드의 효율이 떨어지는 것인지 아니면 멀티스레드 자체의 효율이 별로인 것인지 궁금합니다. 다른 언어는 잘 몰라서 그러는데 다른언어에서 GIL 이 없다고 가정하면 멀티스레드를 자주 사용하나요 ?
혹시나 잘못 이해한 부분이 있으면 알려주세요 ! 답변감사합니다. !
Answer 1
진도미확인 (진도가 안 넘어감)
0
35
1
RuntimeError: There is no current event loop in thread 'MainThread'
0
83
1
chapter 07-01 실행 오류
0
65
1
Chapter05-04 : sum_func의 합이 이중 출력됩니다.
0
76
2
45. 병렬성 2 - Futures(5-1) wait가 의도된 대로 동작하지 않습니다.
0
91
2
멀티스레딩 - 44. 병렬성 1 - Futures(4-2)
0
69
2
chapter05_02 클로저 질문사항 !
0
49
1
LV1 설정
0
86
2
매직 메소드의 호출 방법 차이 문의
0
131
2
왜 numbers리스트를 만들때 str으로 숫자를 감싸나요?
0
92
2
스크랩핑 실습 중 Mac OS 인증서 문제
0
128
1
AsyncIO 멀티 스크랩핑 실습 예제 관련 질문
0
167
1
강의자료가 영상과 다릅니다
0
254
2
closure.cell_contents 초기화 하기 문의
0
128
2
map함수 사용 시, list변환 방법 문의
0
335
2
__mul__ 백터 * 숫지, 백터 * 백터 처리
0
143
1
del처리후 질문입니다.
0
153
1
car_list(car1,car2,car3) 인스턴스 tuple 타입 문의
0
222
1
coroutine에 대한 질문
0
242
1
제너레이터 이터레이터 질문이 있습니다.
0
248
1
atom install package search not working
0
275
1
Magic Method - Not Implemented
0
392
1
가상환경 질문!
0
400
1
병렬처리 추가 질문이 있습니다.
0
241
1

