同其他I/O多路复用和信号驱动一样,linux的epoll(event poll)API可以检查多个文件描述符上的I/O就绪状态。Epoll API的主要优点如下。
当检查大量的文件描述符时,epoll的性能延展性比select和poll高很多。
epoll API既支持水平触发也支持边缘触发。与之相反,select和poll只支持水平触发,而信号驱动I/O只支持边缘触发。
epoll API的核心数据结构称为epoll实例, 它和一个打开的文件描述符相关联。这个文件描述符不是用来做I/O操作的,相反,他说内核数据结构的句柄,这些内核数据结构实现了两个目的。
记录了在进程中声明过的感兴趣的文件描述符列表--interest list。
维护了处于I/O就绪态的文件描述符列表--ready list。
ready list中的成员是interest list的子集。
epoll API由以下3个系统调用组成。
系统调用epoll_create()创建一个epoll实例,返回代表该实例的文件描述符。
系统调用epoll_ctl()操作同epoll实例相关的兴趣列表。通过epoll_ctl(),我们可以增加新的描述符到列表中,将已有的文件描述符从该列表中移除,以及修改代表文件描述符上事件类型的位掩码。
系统调用epoll_wait()返回与epoll实例相关联的就绪列表中的成员。
创建epoll实例:ep

epoll是Linux提供的一种I/O多路复用技术,相较于select和poll,它在处理大量文件描述符时具有更好的性能扩展性。epoll支持水平触发和边缘触发两种模式。它通过epoll_create()创建实例,epoll_ctl()管理兴趣列表,以及epoll_wait()获取就绪文件描述符。当epoll_wait()返回后,文件描述符可能被自动从兴趣列表中移除,如设置了EPOLLONESHOT标志。
最低0.47元/天 解锁文章
3166

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



