介绍
epoll是一种I/O多路复用技术,与poll不同,epoll不仅提供了默认的level-triggered(条件触发)机制,还提供了edge-triggered(边缘触发)机制。
接口
epoll_create:创建实例
epoll_ctl:往实例增加或删除监控的事件
epoll_wait:调用者进程被挂起,等待内核I/O事件的分发
边缘触发与条件触发
条件触发:只要满足事件的条件,比如有数据需要读,就一直不断把这个事件传递给用户。
边缘触发:只有第一次满足条件的时候才触发,之后不会再传递相同的事件了。
优点
- epoll返回的是事件发生的数组,poll返回的是事件就绪的个数,每次poll返回的都需要遍历注册文件描述符的结果数组,因此poll比epll慢
- 边缘触发效率比条件触发更优。
- 避免了用户态-内核态频繁的数据拷贝