linux epoll中事件触发机制
2016-06-17 16:29
591 查看
epoll是linux中的一个系统调用。是linux中的一种I/O复用方式,最早是出现在linux内核2.5.44中。早期的I/O复用主要是基于select和poll实现,但是select方式在在检测具体发生I/O/事件的描述符时,需要对所有的描述符进行循环检测,所以检测时间是描述符总数量的常数倍。epoll实现机制是,当某个描述符发生I/O事件时,直接将描述符加入到相应的链表中,因此应用程序在常数时间内就可以获得发生I/O事件的文件描述符。
epoll事件触发机制主要是分为两种:边缘出发(edge-triggered)和水平出发(level triggered)。对于一个文件描述符,把他加入到epoll监听队列中,当该文件描述符发生可读写事件时,epoll_wait()会返回。对于边缘出发,epoll_wait()只返回一次,即只在该读写事件发生时返回,也就是说如果事件处理函数只读取了该文件描述缓冲区的部分内容时返回,再次调用epoll_wait(),虽然此时该描述符对应缓冲区中还有数据,但epoll_wait()函数不会返回。相反,对于水平出发,它不管是否有事件反生,只要文件描述符对应的缓冲区中有数据可读写,epoll_wait()就会返回。
epoll事件触发机制主要是分为两种:边缘出发(edge-triggered)和水平出发(level triggered)。对于一个文件描述符,把他加入到epoll监听队列中,当该文件描述符发生可读写事件时,epoll_wait()会返回。对于边缘出发,epoll_wait()只返回一次,即只在该读写事件发生时返回,也就是说如果事件处理函数只读取了该文件描述缓冲区的部分内容时返回,再次调用epoll_wait(),虽然此时该描述符对应缓冲区中还有数据,但epoll_wait()函数不会返回。相反,对于水平出发,它不管是否有事件反生,只要文件描述符对应的缓冲区中有数据可读写,epoll_wait()就会返回。
相关文章推荐
- 两个博客地址
- CentOS 必知命令 & Composer部署
- linux mysql 操作命令
- Centos6.5更新e1000网卡驱动
- linux学习笔记一二三四
- 【知识点】patch补丁文件格式
- CentOS7安装Hadoop2.7完整步骤
- Linux命令查看服务器型号及SN
- 【51CTO学院三周年】-感谢恩师马哥让我成为Linux运维工程师
- Linux磁盘分区
- linux 常用
- Linux系统日志及日志分析
- nmon--非常棒的LINUX/AIX性能计数器监测和分析工具
- linux sed
- Crosswalk Project for Linux
- linux下用C编写的基于smtp的邮件发送程序
- CentOS设置用户句柄数与用户进程数
- CoreOS Linux available in China
- CoreOS Linux available in China
- CoreOS Linux available in China