Develop
2003.04.23 10:45
[c] 소켓의 세가지 동작모드
조회 수 6933 댓글 0
블로킹(blocking) 모드
소켓을 처음 생성하면 blocking 모드의 소켓이 생성된다.
blocking 모드의 소켓은 어떤 소켓 관련 시스템 콜을 호출하였을 때 네트웍 시스템(TCP/IP)이 동작을 완료할 때까지 응용 프로세스가 멈추어 있게(block)되는 소켓을 말한다.
논블로킹(non-blocking) 모드
소켓 관련 시스템 콜에 대하여 네트웍 시스템이 일단 결과를 바로 리턴하여 응용 프로그램이 block 되지 않게 하는 소켓을 말한다.
소켓 관련 시스템 콜 중에 block될 수 있는 것은
listen(), connect(), accept(), send(), recv(), close() 등이 있다.
비동기(asynchronous) 모드
non-blocking 모드에서 처럼 block 될 수 있었던 소켓 시스템 콜에 대해서 일단 리턴을 하고 시스템 콜의 해당 동작이 완료 되면 비동기적으로(asynchronously) 그 결고를 응용 프로그램에게 알려주는 소켓의 동작모드이다.
세가지 동작 모드를 전화 통화에 비유할 수 있다.
blocking 모드는 전화를 하여 원하는 사람이 전화를 받을 수 없는 상태라면 그 사람이 받을 때까지 계속 기다리는(blocking) 모드이고,
non-blocking 모드는 그 사람이 받을 수 없다면 일단 전화를 끊고(함수가 리턴), 그 사람과 통화가 될 때까지 반복하여(polling) 전화를 거는 모드이다.
비동기(asysnchronous) 모드는 전화를 걸었을 때 원하는 사람이 통화를 할 수 없으면 나중에 (비동기적으로) 전화를 걸어달라고 부탁하고 전화를 끊는 것과 같다.
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
801 | Develop | [c] 재미있는 코딩.. | hooni | 2003.04.23 | 21381 |
800 | Develop | [c] 전위 표기법으로 연산 예제.. | hooni | 2013.04.23 | 9309 |
799 | Develop | [c] 정사각배열의 서브 배열의 최대 값 구하기 | hooni | 2003.04.23 | 7035 |
798 | Develop | [c] 정수를 2진수로 변환 (재귀,비트연산) | hooni | 2003.04.23 | 7598 |
797 | Develop | [c] 지나가는 패킷 잡기 | hooni | 2003.04.23 | 8830 |
796 | Develop | [c] 지폰(gphone) 소스.. 수정(암호화) | hooni | 2013.04.23 | 7438 |
795 | Develop | [c] 최단거리 알고리즘 & 예제소스.. 13 | hooni | 2013.04.23 | 10176 |
794 | Develop | [c] 최대공약수 알고리즘 (유클릿) | hooni | 2003.04.23 | 8892 |
793 | Develop | [c] 최대공약수, 최소공배수, 서로소 구하기 (펌) | hooni | 2013.04.23 | 11189 |
792 | Develop | [c] 캘린더 양음 변환 함수 | hooni | 2003.04.23 | 8746 |
791 | Develop | [c] 컴파일러 DFA구현^^ 입력 받아 실행 4 | hooni | 2003.04.23 | 8131 |
790 | Develop | [c] 컴파일러 선행처리기 따라하기.. | hooni | 2003.04.23 | 6692 |