Multi Thread란...

조회 수 7994 추천 수 104 2002.10.11 11:43:53
전 전산과 커리큘럼으로 익힌게 아니라서 교과서적인 내용으로는 설명드리기 어렵습니다.제 스타일로 간단히 설명을 해보겠습니다.

모든 실행파일(Windows에서는 .exe, .com, 그 외 os의 실행가능한 모든 파일)은 os위에서 프로세스라는 단위로 리소스를 할당받고 실행됩니다.
하나의 exe는 하나의 프로세스라고 봐도 됩니다.

모든 프로세스는 하나 이상의 스레드를 가지고 있습니다.
예로 main()으로 시작하는 어플리케이션의 엔트리포인트는 기본 스레드의 시작점이라 할 수 있습니다.멀티스레드의 경우 이 엔트리 포인트를 여러개 주는 것입니다.

모든 스레드는 각각 Thread Context라 불리는 자료구조를 가지고 있습니다.해당 스레드의 스케쥴링할 당시의 상태를 저장해놓은것이죠.ip레지스터(코드의 어드레스를 가리키는 레지스터),sp레지스터(스택 포인터레지스터)를 비롯한 모든 레지스터 상태와 기타 정보를 가지고 있습니다.따라서 각 스레드는 독립적인 상태를 유지할수 있습니다.

그럼 스레드는 어떻게 스케쥴링(수행)되느냐?
os는 메인보드의 타이머 칩에 인터럽트 주기를 세팅해놓고 타이머 인터럽트를 주기적으로 받습니다.이로서 어플리케이션이 cpu운영권을 os에 반납하거나 특정 io인터럽트등을 이용하지 않고서도 cpu운영권을 정해진 시간 주기로 얻어낼수 있습니다.

스레드가 100개쯤 있다고 치면 타이머 인터럽트가 발생할때마다 os에서 어떤 스레드를 스케쥴링할지 결정하는것입니다.

타이머 인터럽트가 발생했을때, 이전 스레드를 비활성화 시키고 다른 스레드를 또 활성화시키고, 또 다음번 타이머 인터럽트가 발생했을때 다른 스레드를 활성화시키고..이런식으로 짧게 짧게 여러 스레드를 돌려가며 스케쥴링 시키면 동시에 여러개의 스레드가 돌아가는것으로 보이게 됩니다.

개념적으로 한 스레드당 20ms씩스케쥴링하기로 했다면 20ms마다 타이머 인터럽트를 받고 그때마다 한번씩 스케쥴링할 스레드를 바꿔준다면 20*100ms가 지났을 시점에서 100개의 스레드는 모두 조금씩 실행된 상태겠죠.

멀티 프로세스도 마찬가지인데 Windows의 경우는 실제 프로세스단위의 스케쥴링은 없고 내부적으론 모두 스레드 단위로 스케쥴링을 시킵니다.
도움이 되셨는지? 이해 안되는 부분은 추가 질문해주세요.그리고 질문은 리플로 달지 마시고 바로 게시물로 써주시기 바랍니다.



파일 첨부

여기에 파일을 끌어 놓거나 파일 첨부 버튼을 클릭하세요.

파일 크기 제한 : 0MB (허용 확장자 : *.*)

0개 첨부 됨 ( / )
List of Articles
번호 제목 글쓴이 날짜 조회 수sort
43 [re] [질문]HeightField에서 LOD는 안쓰시나요? [6] protian 2004-06-10 7706
42 [필독] 프로그래밍, 신이 내린 최고의 노가다 [1] 베지타 2002-10-21 7863
» Multi Thread란... 여치 2002-10-11 7994
40 질문~~~ [1] clever98 2004-06-22 8148
39 엔진 버전업에 관해 [1] 답게 2003-08-26 8198
38 HTTP 에서 응답메세지중에 본문의 크기에 대한 부분이 나오지를 않습니다. [5] 바하무트 2004-03-23 8491
37 개나소나 만드는 바이러스강좌#3 여치 2002-04-22 8827
36 [re] o/s의 내부에 대해 자세하게 알고싶은데여... [3] 여치 2002-10-12 9020
35 [re] runtime assembler..... 여치 2002-09-14 9111
34 마소의 도전...X-box의 후기 베지타 2003-01-15 9135
33 메모리카피는 어떻게 이루어지나? [3] 여치 2002-10-19 9593
32 스핀락 구현하기 여치 2002-10-19 9607
31 [re] [질문] 게임 [1] 여치 2003-07-08 9826
30 direct3d8.0 hongiro 2002-11-07 10222
29 3D Programming에 관한 책을 추천해주실 수 있으신지요... 천세진 2002-10-11 10475
28 runtime assembler..... [1] gg 2002-09-12 10855
27 소켓 hongiro 2002-10-17 11223
26 Windows NT 4.0 이상 Completion I/O Port를 이용한 send,recv 여치 2002-10-19 11882
25 개나소나 만드는 바이러스 강좌#2 여치 2002-04-22 12090
24 [질문] 게임 hongiro 2003-07-07 12304



XE Login

天安門大屠殺 六四天安門事件 反右派鬥爭 大躍進政策 文化大革命 六四天安門事件 The Tiananmen Square protests of 1989 天安門大屠殺 The Tiananmen Square Massacre 反右派鬥爭 The Anti-Rightist Struggle 大躍進政策 The Great Leap Forward 文化大革命 The Great Proletarian Cultural Revolution 人權 Human Rights 民運 Democratization 自由 Freedom 獨立 Independence 多黨制 Multi-party system 民主 言論 思想 反共 反革命 抗議 運動 騷亂 暴亂 騷擾 擾亂 抗暴 平反 維權 示威游行 法輪功 Falun Dafa 李洪志 法輪大法 大法弟子 強制斷種 強制堕胎 民族淨化 人體實驗 胡耀邦 趙紫陽 魏京生 王丹 還政於民 和平演變 激流中國 北京之春 大紀元時報 九評論共産黨 獨裁 專制 壓制 統一 監視 鎮壓 迫害 侵略 掠奪 破壞 拷問 屠殺 肅清 活摘器官 障テ社會 誘拐 買賣人口 遊進 走私 毒品 賣淫 春畫 賭博 六合彩 台灣 臺灣 Taiwan Formosa 中華民國 Republic of China 西藏 土伯特 唐古特 Tibet 達償ワ喇嘛 Dalai Lama 新疆維吾爾自治區 The Xinjiang Uyghur Autonomous Region free tibet