您的位置:首页 > 理论基础 > 计算机网络

【网络】select/poll/epoll事件处理图示

2017-03-24 10:51 267 查看
select/poll/epoll I/O多路复用

没有文字说明,只有好的文章链接:重点都是epoll

epoll的实现机制讲解:

http://www.cnblogs.com/sniperHW/p/3619384.html

epoll的 LE/ET 模式演示分析:

http://www.cnblogs.com/yuuyuu/p/5103744.html

epoll 源码实现分析链接:

http://blog.csdn.net/xiaoyu15407/article/details/46620911



select/poll/epoll 对比分析:

可检测最大文件描述符:

> seletc : 1024    受限制于FD_SIZE,可以修改,但不建议;
> poll   : 65535 系统允许的最大文件描述符数量;
> epoll  :  65535  系统允许的最大文件描述符数量;


事件的注册过程:

seletc:第一个参数,指定被监听的文件描述符的总数,一般是最大的文件描述符+1,三个fd_set:readfds,writefds,exceptfds,是一个结构体,内含整形数组,数组每一个元素的每一Bit位表示一个fd;exceptfds一般处理带外数据; 每次需要重复fd的注册事件。工作在LT模式;
采用轮询来检测就绪事件,效率低,随着文件描述符的增多,效率降低;


通过宏进行访问和修改:

FD_ZERO :清除fdset的所有位;
FD_SET  :设置fdset上的位fd;
FD_CLR  :清除fdset上的位fd;
int FD_ISSET: 测试fdset上的位fd是否被设置;


poll : 和select类似,不过不是采用值-结果的形式注册和修改参数,通过pollfd结构体的events注册事件,而内核则是修改revents来通知事件的发生;工作在LT模式

效率低,和select一样;


epoll:则是通过内核的事件表来进行一系列的监听,上面已经很详细,不做赘述,默认工作在LT模式;

效率高,采用回调的方式;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: