[八股]select,poll与epoll

本文对比了select、poll和epoll三种操作系统中实现IO多路复用的方法,讨论了它们的工作原理、优缺点,重点介绍了epoll利用红黑树优化性能的特点和水平/边缘触发模式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

select,poll,epoll的区别

这个问题考察的主要是操作系统和IO模型

select,poll,epoll是实现IO多路复用的三种方式

  • 现代操作系统采用虚拟存储器来实现内存管理,操作系统的核心是内核,出于安全性考虑,将虚拟空间分为了用户空间和内核空间。

  • select将所有的Socket连接放到一个文件描述符集合中,之后该集合会从用户空间拷贝到内核空间,内核采用遍历的方式检查是否有事件产生,当检查到产生事件时,内核j将修改内核空间中的文件描述符集合,之后将该集合从内核空间拷贝到用户空间。用户空间将遍历集合找出可读/写的Socket

    该方式存在几个问题:

    • 文件描述符集合最大长度为1024(x86)或2048(x64)
    • 进行了两次拷贝
    • 进行了两次遍历
  • poll使用了链表实现了动态数组,相较于select没有了文件描述符集合长度的限制,但其他方面没有什么太大变化

  • 关于epoll:

    • epoll在内核空间使用红黑树来跟踪需要检测的文件描述符,相较于select/poll需要每次传入所有的Socket列表,epoll只需要传入待检测的Socket,由内核中的红黑树来保存所有待检测的Socket,时间复杂度由O(N)优化到了O(logN)
    • epoll维护了一个就绪事件链表,当红黑树上的某个Socket产生事件时,将由回调函数将其加入就绪事件链表中,这里相较与select/poll省去了遍历的时间。之后,这个就绪时间列表将从内核空间拷贝到用户空间
    • epoll有水平触发和边缘触发两种模式,水平触发在有可读事件产生时会不断苏醒知道内核缓冲区的数据被读完,而边缘触发只会苏醒一次不确保缓冲区被读完。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

辰宝IWZ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值