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

select/poll/epoll I/O多路复用

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

  1. epoll的实现机制讲解:
    http://www.cnblogs.com/sniperHW/p/3619384.html
  2. epoll的 LE/ET 模式演示分析:
    http://www.cnblogs.com/yuuyuu/p/5103744.html
  3. 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模式;
效率高,采用回调的方式;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值