Overlapped I/O(중첩입출력)란 무엇인가?

조회 수 31150 추천 수 98 2002.10.19 03:56:54
예전에 하이텔 게제동 네트웍 게시판에 올렸던 글입니다.

제  목:[답변] 중첩이란 단어를 쓰는 이유...             관련자료:없음  [2547]
보낸이:유영천  (yuchi   )  2001-02-13 18:27  조회:274
동시에 여러개의 i/o를 처리하기 때문입니다.
영어단어 그대로 해석하자니 중첩이란 말이 되었는데 다중이란
표현을 사용했다면 약간 더 이해가 쉬웠을지도...

예를 들면 버클리 소켓의 recv()함수를 수행한다고 할때 100개의 소켓에
대해 동시에 recv()함수를 수행하려면 스레드 100개가 필요합니다.

overlapped(중첩) io 가 다른 점은 1개의 스레드만으로도 100개의 소켓에
대  동시 recv(물론 send나 기타 io도 포함)가 가능하다는 점입니다.
어떻게 가능한가?
디바이스 드라이버에 의존합니다.
네트워크 디바이스 드라이버는 몇개의 계층으로 나뉘는데 일반적인
소켓 api의 바로 하위 계층, 그러니까 드라이버로 치면 최상위 계
층에 위치한 것이 ndis protocol 드라이버입니다.
일단 랜카드나 기타 디바이스에 도착한 모든 패킷은 프로토콜 드라
이버 계층까지 올라옵니다.
WSASend,WSARead,ReadFile,WriteFile등 overlapped io를 지원하는 api로
recv등을 요청했다면 프로토콜 드라이버에 패킷을 받을 메모리를(실제 버
퍼 메모리는 유져프로그램쪽에서 할당) 할당해 놓고 io가 pending
(overlapped방식에서 error코드로 발생하는 IO_PENDING이 이것입니다)
되었음을 표시만 해둡니다.

네트웍 디바이스의 인터럽트에 의해 패킷이 프로토콜 드라이버까지
올라오면 여기서 pending된 io가 있는지 확인하고 있으면 해당 io
(소켓등)의 버퍼에 패킷을 채워주는 것입니다.
따라서 별도의 스레드가 필요없고 하드웨어 인터럽트에 의해 움직
이므로 추가로 cpu자원을 잡아먹지 않는것입니다.물론 동시에(실제
로 정말 동시는 아니지만) 복수의 io를 처리할 수 있구요.


파일 첨부

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

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

0개 첨부 됨 ( / )
List of Articles
번호 제목 글쓴이 날짜 조회 수
43 [re] 오랜만에 질문 하나 드립니다~ [1] 여치 2003-08-08 7193
42 [질문] 게임 hongiro 2003-07-07 12297
41 [re] [질문] 게임 [1] 여치 2003-07-08 8310
40 [re] [질문] 게임 [2] hongiro 2003-07-08 6641
39 [퍼온글] 프로그래밍의 도 여치 2003-06-20 6141
38 NPC 길찾기 시스템과 맵구조에 대한 질문이에요 ^^ [2] 풍이 2003-06-03 7588
37 [펌] 어릴적 기억 [1] 청년 2003-03-18 6225
36 마소의 도전...X-box의 후기 베지타 2003-01-15 9120
35 swicth 문에 대한 질문 [2] hongiro 2002-11-14 6358
34 direct3d8.0 hongiro 2002-11-07 10214
33 [re] direct3d8.0 여치 2002-11-07 5533
32 [필독] 프로그래밍, 신이 내린 최고의 노가다 [1] 베지타 2002-10-21 7758
31 지금 게임학원에 hongiro 2002-10-20 6325
30 [re] 지금 게임학원에 [1] 여치 2002-10-20 6171
29 멀티스레드 프로그래밍에서 동기화는 왜 필요할까? [1] 여치 2002-10-19 5848
28 가상함수는 어떻게 호출되나? 여치 2002-10-19 6657
27 메모리카피는 어떻게 이루어지나? [3] 여치 2002-10-19 9538
26 정밀한 퍼포먼스 체크 여치 2002-10-19 7184
» Overlapped I/O(중첩입출력)란 무엇인가? 여치 2002-10-19 31150
24 sse와 정수 레지스터의 연산속도 비교 여치 2002-10-19 5421



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