epoll的两种工作模式
时间: 2024-01-24 19:37:26 浏览: 35
epoll是Linux系统提供的一种I/O多路复用机制,它有两种工作模式:LT(Level Triggered)模式和ET(Edge Triggered)模式。
1. LT(Level Triggered)模式:
在LT模式下,当某个文件描述符就绪时,epoll_wait会立即返回,并告诉用户进程文件描述符可读或可写。如果用户进程没有对该文件描述符进行读写操作,那么每次调用epoll_wait时都会返回该文件描述符,直到用户进程对其进行读写操作。
2. ET(Edge Triggered)模式:
在ET模式下,当某个文件描述符就绪时,epoll_wait仅在该文件描述符状态发生变化时才会返回。换句话说,只有当文件描述符从未就绪变为就绪时,epoll_wait才会返回就绪事件,而不是每次都返回该文件描述符。
需要注意的是,在ET模式下,为了确保不丢失事件,用户进程需要将文件描述符设置为非阻塞模式,并使用循环来读取所有就绪事件,直到epoll_wait返回0。同时,在ET模式下,epoll_wait只能与边缘触发的IO函数(如recv、send等)一起使用,否则可能会导致事件丢失。
相关问题
这两种模式在哪个函数中设置
这两种模式是在 epoll_ctl() 函数中设置的。
epoll_ctl() 函数用于向 epoll 实例中添加、修改或删除文件描述符,并指定要监听的事件和触发模式。它接受一个操作类型参数,可以是 EPOLL_CTL_ADD、EPOLL_CTL_MOD 或 EPOLL_CTL_DEL,分别表示添加、修改或删除文件描述符。
当调用 epoll_ctl() 函数添加或修改文件描述符时,可以通过设置 epoll_event 结构体中的 events 字段来指定要监听的事件类型。其中,EPOLLIN 表示可读事件,EPOLLOUT 表示可写事件,EPOLLERR 和 EPOLLHUP 表示错误和挂起事件。
除了设置事件类型外,还可以通过设置 epoll_event 结构体中的 epoll_data 字段来传递用户自定义数据。这个字段可以是一个整数、指针或联合体,用于在事件触发时传递给应用程序。
至于触发模式的设置,可以通过在 epoll_ctl() 函数中设置 epoll_event 结构体中的 epoll_event.events 字段的边缘触发标志 EPOLLET 来启用边缘触发模式。如果不设置该标志,则使用默认的水平触发模式。
需要注意的是,一旦文件描述符被添加到 epoll 实例中并开始监听事件,触发模式将会一直有效,直到其被修改或从 epoll 实例中删除。
因此,通过在 epoll_ctl() 函数中设置相应的参数,可以选择使用水平触发或边缘触发模式来监听文件描述符的事件。
poll epoll
poll和epoll是两种用于I/O多路复用的机制。它们的区别主要体现在以下几个方面:
1. 返回的文件描述符不同:poll返回所有用户关注的文件描述符(就绪的和未就绪的),而epoll只返回就绪的文件描述符。因此,poll的时间复杂度为O(n),而epoll的时间复杂度为O(1)。
2. 函数数量不同:poll系统调用只有一个函数,而epoll系统调用则是一组函数,包括epoll_create、epoll_ctl和epoll_wait,分别用于创建文件描述符、操作epoll内核事件表和检测文件描述符上的事件。
3. 函数参数不同:poll将用户关注的事件类型和内核修改的事件类型分离开表示,而epoll则是由内核事件表维护用户关注的文件描述符上的事件类型。
4. 调用时文件描述符的拷贝不同:poll每次调用都需要将用户空间的数据拷贝到内核空间,返回时又将内核空间的数据再拷贝到用户空间,而epoll只会在调用epoll_ctl时拷贝一次,epoll_wait调用时只从内核空间向用户拷贝就绪的文件描述符。
5. 内核实现方式不同:poll采用轮询的方式检测就绪事件,而epoll则采用回调方式。
6. 支持的工作模式不同:poll只能在LT(Level Triggered)模式下工作,而epoll则支持更高效的ET(Edge Triggered)模式。
综上所述,poll和epoll在返回的文件描述符、函数数量、函数参数、调用时文件描述符的拷贝、内核实现方式和支持的工作模式等方面存在差异。
#### 引用[.reference_title]
- *1* *2* *3* [I/O复用——poll和epoll](https://blog.csdn.net/love10_1314/article/details/97296680)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]