select poll epoll详解
时间: 2023-04-29 17:03:34 浏览: 198
"select" 和 "poll" 都是 I/O 多路复用的方式,它们都能让一个进程同时监听多个文件描述符 (socket、文件、管道等),当其中有一个或多个可读/可写时,进程就可以对其进行读/写操作。
"select" 和 "poll" 的不同之处在于:
- "select" 的最大监听文件描述符数量受限于 FD_SETSIZE,通常为 1024,因此当监听的文件描述符数量超过 1024 时,就不能使用 "select" 了。
- "poll" 不存在上述限制,它能监听的文件描述符数量更大。
"epoll" 是 Linux 内核为了解决 "select" 和 "poll" 的缺陷而提出的一种 I/O 多路复用机制,它能监听的文件描述符数量比 "select" 和 "poll" 更大,且效率更高。
相关问题
selectpollepoll
select、poll和epoll是Linux下的三种I/O多路复用机制。
select是最古老的一种,它通过轮询的方式来检查多个文件描述符是否处于就绪态。当文件描述符就绪时,select会通知应用程序进行读写操作。然而,在连接数少并且连接都十分活跃的情况下,select的性能可能不如其他两种。因为select的通知机制需要回调多个函数,这会导致性能下降。
poll是select的改进版本,它也是通过轮询的方式来检查文件描述符的就绪态。和select不同的是,poll使用了结构体数组来传递文件描述符信息,减少了函数调用的次数。但是,随着文件描述符数量的增加,poll的效率会线性降低。
而epoll是最新的一种I/O多路复用机制,它采用了回调机制。当文件描述符就绪时,epoll会通过回调机制直接调用相应的回调函数,减少了函数调用的开销。与select和poll相比,epoll在大量活跃的文件描述符情况下具有更好的性能,因为它的效率不受文件描述符数量的影响。使用epoll需要先调用epoll_create()函数创建一个epoll的句柄,然后将需要监视的文件描述符添加到epoll中。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *3* [select,poll和epoll详解](https://blog.csdn.net/u010306832/article/details/119942290)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *2* [select、poll、epoll详解](https://blog.csdn.net/fengyuyeguirenenen/article/details/124234675)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
select/poll/epoll
select、poll和epoll都是I/O多路复用机制,用于同时监听多个I/O事件的状态。它们的基本原理是通过查询所有socket连接,如果有数据到达,就通知用户进程。\[2\]这些机制都属于同步I/O,需要在事件就绪后自己负责读写,并且读写过程会阻塞。而异步I/O则不会自己读写和阻塞,而是负责将数据从内核拷贝到用户空间。\[3\]
select是最早出现的I/O多路复用机制,它使用fd_set数据结构来存储需要监听的文件描述符,通过调用select函数来等待事件的发生。select的缺点是效率较低,因为每次调用select都需要将所有的文件描述符集合传递给内核,而且select的文件描述符数量有限制。\[1\]
poll是select的改进版本,它使用pollfd数据结构来存储需要监听的文件描述符,通过调用poll函数来等待事件的发生。poll相对于select的优点是没有文件描述符数量的限制,但仍然需要将所有的文件描述符集合传递给内核。\[1\]
epoll是Linux特有的I/O多路复用机制,它使用epoll_event数据结构来存储需要监听的文件描述符,通过调用epoll_ctl函数来注册事件,然后通过调用epoll_wait函数来等待事件的发生。epoll的优点是没有文件描述符数量的限制,而且在注册事件时只需要拷贝一次文件描述符到内核,而不是在等待事件时重复拷贝。epoll还支持水平触发和边沿触发两种模式,边沿触发模式可以降低同一个事件被重复触发的次数。\[1\]
总结来说,select、poll和epoll都是用于实现I/O多路复用的机制,它们的选择取决于具体的应用场景和需求。select适用于连接数量多但活动连接较少的情况,poll适用于连接数量多且活动连接较多的情况,而epoll适用于连接数量多但活动连接较少的情况,并且具有更高的效率和更灵活的触发模式。\[1\]
#### 引用[.reference_title]
- *1* *3* [select、poll、epoll简介](https://blog.csdn.net/HuYingJie_1995/article/details/130516595)[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]
- *2* [select、poll、epoll详解](https://blog.csdn.net/ljjjjjjjjjjj/article/details/129720990)[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 ]
阅读全文