epoll与select、poll区别(笔记)

select限制:

    用select实现的并发服务器,能达到的并发数,受两方面的限制:

    1.一个进程能打开的最大文件描述符限制。这可以通过调整内核参数。

    2.select中的fd_set集合容量的限制(FD_SETSIZE),这需要重新编译内核。

poll的限制:    

    一个进程能打开的文件描述符个数是有限的。

两者共同点:

    内核要遍历所有文件描述符,直到找到发生事件的文件描述符。

查看一个进程能打开的最大文件描述符:    

    ulimit -n 

epoll与select、poll的区别:

    1.相比于select与poll最大的好处在于它不会随着监听fd数目的增长而降低效率。

    2.内核中的select与poll的实现是采用轮询来处理的,轮询的fd数目越多,自然耗时越多。

    3.epoll的实现是基于回调的,如果fd有期望的事件发生就通过回调函数将其加入epoll就绪队列中,也就是说它只关心“活跃”的fd,与fd数目无关。

    4.在内核把fd消息通知给用户处理方面,select和epoll采用了内存拷贝方法。而epoll采用了共享内存的方式。

    5.epoll不仅会告诉应用程序有I/O事件到来,还会告诉应用程序相关的信息,这些信息是应用程序填充的。因此根据这些信息应用程序就能直接定位到事件,而不必遍历整个fd集合。

    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值