多路复用I/O:select、poll与pselect详解
1. 非阻塞I/O的局限性
非阻塞I/O可让应用程序发出I/O请求,返回特殊错误条件而非阻塞。但它效率低下,原因有二:
- 进程需按任意顺序不断发出I/O操作,等待某个打开的文件描述符准备好进行I/O,这是糟糕的程序设计。
- 若程序能休眠,释放处理器用于其他任务,仅在一个或多个文件描述符准备好进行I/O时被唤醒,效率会更高。
2. 多路复用I/O概述
多路复用I/O允许应用程序同时阻塞多个文件描述符,并在其中任何一个准备好读写而不阻塞时收到通知。其工作流程如下:
1. 多路复用I/O:告知哪些文件描述符准备好进行I/O。
2. 无准备好的?休眠直到一个或多个文件描述符准备好。
3. 被唤醒!哪些准备好了?
4. 处理所有准备好进行I/O的文件描述符,不阻塞。
5. 返回步骤1。
Linux提供了三种多路复用I/O解决方案:select、poll和epoll接口。下面重点介绍select和poll。
3. select()系统调用
3.1 函数原型
#include <sys/select.h>
int select (int n,
fd_set *readfds,
fd_set *writefds,
fd_set *exceptfds,
struct timeval *timeout);
FD_CLR(
超级会员免费看
订阅专栏 解锁全文
18

被折叠的 条评论
为什么被折叠?



