epoll

介绍

epoll是一种I/O多路复用技术,与poll不同,epoll不仅提供了默认的level-triggered(条件触发)机制,还提供了edge-triggered(边缘触发)机制。

接口

epoll_create:创建实例
epoll_ctl:往实例增加或删除监控的事件
epoll_wait:调用者进程被挂起,等待内核I/O事件的分发

边缘触发与条件触发

条件触发:只要满足事件的条件,比如有数据需要读,就一直不断把这个事件传递给用户。
边缘触发:只有第一次满足条件的时候才触发,之后不会再传递相同的事件了。

优点

  • epoll返回的是事件发生的数组,poll返回的是事件就绪的个数,每次poll返回的都需要遍历注册文件描述符的结果数组,因此poll比epll慢
  • 边缘触发效率比条件触发更优。
  • 避免了用户态-内核态频繁的数据拷贝

你可能感兴趣的:(网络编程,网络)