epoll 原理
作者:互联网
epoll_wait的工作流程:转:https://blog.csdn.net/eyucham/article/details/86502117
- epoll_wait调用ep_poll,当rdlist为空(无就绪fd)时挂起当前进程,直到rdlist不空时进程才被唤醒。
- 文件fd状态改变(buffer由不可读变为可读或由不可写变为可写),导致相应fd上的回调函数ep_poll_callback()被调用。
- ep_poll_callback将相应fd对应epitem加入rdlist,导致rdlist不空,进程被唤醒,epoll_wait得以继续执行。
- ep_events_transfer函数将rdlist中的epitem拷贝到txlist中,并将rdlist清空。
- ep_send_events函数(很关键),它扫描txlist中的每个epitem,调用其关联fd对用的poll方法。此时对poll的调用仅仅是取得fd上较新的events(防止之前events被更新),之后将取得的events和相应的fd发送到用户空间(封装在struct epoll_event,从epoll_wait返回)。
LT与ET模式 转:http://blog.chinaunix.net/uid-28541347-id-4273856.html
标签:rdlist,epoll,events,fd,原理,poll,ep 来源: https://www.cnblogs.com/20170722-kong/p/13994450.html