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_系列函数);
对于一个套接字上的输入操作,第一步通常涉及等待数据从网络到达。当所等待分组到达时,它被复制到内核中的某个缓冲区。第二步就是把数据从内核缓冲区复制到应用进程缓存区。
信号驱动式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相匹配。