什么是epoll?
epoll是linux内核为处理大批量文件描述符而作了改进的poll,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大
量并发连接中只有少量活跃的情况下的系统CPU利用率。另一点原因就是获取事件的时候,它无须遍历整个被侦听的描述符集,只要
遍历那些被内核IO事件异步唤醒而加入Ready队列的描述符集合就行了。
注:epoll除了提供select/poll那种IO事件的水平触发(Level Triggered)外,还提供了边缘触发(Edge Triggered),这就使得用户空
间程序有可能缓存IO状态,减少epoll_wait/epoll_pwait的调用,提高应用程序效率。
注:epoll文件描述符用完后,直接用close关闭即可,非常方便。事实上,任何被侦听的文件符只要其被关闭,那么它也会自动从被侦
听的文件描述符集合中删除,很是智能。
epoll相关的系统调用有:epoll_create, epoll_ctl和epoll_wait。
epoll_create:
返回值:>0:非空文件描述符;
-1:函数调用失败,同时会自动设置全局变量errno;
epoll_ctl:用来添加/修改/删除需要侦听的文件描述符及其事件.
epoll的事件注册函数,它不同于select()是在监听事件时告诉内核要监听什么类型的事件,而是在这里先注册要监听的事件类型。