为了了解epoll和select之间的区别,我读了几本网络书籍,但它们只略微涵盖了这些概念。如果你们能为我提供详细的关键区别,我将不胜感激。
提前感谢
发布于 2011-06-10 15:56:30
select是用于执行异步IO的标准Unix工具。它的编程接口很古怪,在大多数Unixes中的实现充其量也是平庸的。它还对进程可以监视的描述符的最大数量施加了限制,这在应用程序中是不方便的。关于效率,select的性能通常随着描述符的数量而线性下降。
在编程接口和效率方面,epoll比select有了巨大的改进,但只在2.6版以后的Linux中提供。其他的联盟也有他们的特殊呼叫。
发布于 2015-04-09 15:50:54
当调用select()时,select总是向内核传递描述符。
但epoll在调用epoll_ctl()时只传递一次描述符,并通过调用epoll_wait()获取事件。
并在使用select时将0循环到max_descriptor以检查事件。
但是当使用epoll时,用于检查事件的事件发生描述符的循环。
这些因素决定了性能的不同。
并且由于select使用位数组,所以它有描述符的最大数目的限制。
但是epoll没有限制,因为它使用结构数组。
而select存在于大多数平台(windows、linux、unix、bsd)中。
但是epoll只存在于linux中。
当然,在其他平台上也存在epoll的替代品( windows中的IOCP、bsd中的kqueue等)。
https://stackoverflow.com/questions/6303507
复制相似问题