第6章——I/O复用

I/O复用使用场合:

1、当客户处理多个描述符时(通常是交互式输入和网络套接字)。

2、一个客户同时处理多个套接字是可能的。

3、如果一个TCP服务器既要处理监听套接字,又要处理已连接套接字。

4、当一个服务器既要处理TCP,又要处理UDP。

5、当一个服务器要处理多个服务或者多个协议。

Unix下5种I/O模型:

1)阻塞式I/O;

2)非阻塞式I/O;

3)I/O复用(select和poll);

4)信号驱动式I/O(SIGIO);

5)异步I/O(POSIX的aio_系列函数);

        对于一个套接字上的输入操作,第一步通常涉及等待数据从网络到达。当所等待分组到达时,它被复制到内核中的某个缓冲区。第二步就是把数据从内核缓冲区复制到应用进程缓存区。

第6章——I/O复用第6章——I/O复用第6章——I/O复用第6章——I/O复用第6章——I/O复用


        信号驱动式I/O是由内核通知我们何时可以启动一个I/O操作,而异步I/O模型是由内核通知我们I/O操作何时完成。

同步I/O和异步I/O对比:

    同步I/O操作导致请求进程阻塞,直到I/O操作完成;

    异步I/O操作不导致请求进程阻塞。

    前四种模型都是同步操作,因为其中真正的I/O操作(recvfrom)将阻塞进程。只有异步I/O模型与POSIX定义的异步I/O相匹配。