• 카테고리

    질문 & 답변
  • 세부 분야

    프로그래밍 언어

  • 해결 여부

    미해결

futures 이해 및 GIL 에 대한 질문

21.07.27 16:21 작성 조회수 143

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

problem ) GIL -> 두 개 이상의 스레드가 동시에 실행 될 때 GIL 에 의해서 단일 스레드만 실행이됨. 

멀티 스레드의 경우 문맥교환에 필요한 것을 고려하면 오히려 단일 스레드보다 성능이 떨어짐.

solution) concurrnet.futures 모듈을 사용해서 해결하고자함 .

processpoolexecutor 과 threadpoolexecutor 두 클래스를 사용해서 해결하는데 

멀티스레드로 처리하느냐  혹은 멀티 프로세스를 처리하느냐의 차이인 것인데

q1 )멀티스레드로 처리하면 GIL에 결국 걸려야 하는 것 아닌가요 ??(GIL 에 걸리지 않게 멀티스레드를 사용하게 한 것이라면 어떻게 그렇게 만든 것 인지 궁금합니다)

q2)GIL 때문에 멀티스레드의 효율이 떨어지는 것인지 아니면 멀티스레드 자체의 효율이 별로인 것인지 궁금합니다. 다른 언어는 잘 몰라서 그러는데 다른언어에서 GIL 이 없다고 가정하면 멀티스레드를 자주 사용하나요 ?

혹시나 잘못 이해한 부분이 있으면 알려주세요 ! 답변감사합니다. !

답변 1

답변을 작성해보세요.

0

안녕하세요.

싱글스레드도 충분히 빠를 수 있게 설계되었습니다.

잘 이해하셨어요

다중 계산 처리는 멀티프로세싱을 주로 사용해서 처리해요~