poll epoll
时间: 2023-08-17 22:06:31 浏览: 48
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 ]