当前位置: 首页 > news >正文

Linux I/O多路复用技术详解:Select、Poll 和 Epoll

通俗解释:I/O多路复用三剑客

生活中的比喻

想象你在经营一个快递驿站,顾客来取快递:

1. Select - 传统方法(挨个问)

// 就像你每隔一段时间就问每个顾客:while(true){for(每个顾客){问:"有你的快递吗?"}// 处理有快递的顾客}

特点:

  • 效率低:不管有没有快递,每个人都要问一遍
  • 人数限制:最多只能服务1024个顾客(FD_SETSIZE限制)
  • 开销大:每次都要重新准备名单

2. Poll - 改进版(填表格)

// 顾客先填好表格放在桌上,你只需要检查表格structpoll{int顾客编号;short事件;// "有快递"、"要寄件"};while(true){扫描所有表格();// 扫描所有顾客的表格// 处理有事件的顾客}

改进:

  • 无人数限制:表格可以无限长(链表结构)
  • 稍微高效:但还是要扫描所有人

3. Epoll - 智能系统(叫号机)

// 安装了一套智能系统:1.顾客进门先登记(epoll_ctl)2.有快递时,系统自动亮灯通知(epoll_wait只返回有事件的)3.你只需要处理亮灯的顾客// 系统还有两种工作模式:// LT模式:快递没取走,灯一直亮(反复通知)// ET模式:快递来了只闪一下灯,取不走就要自己负责

技术对比表

特性SelectPollEpoll
最大连接数1024无限制无限制
工作效率O(n),每次都扫描所有O(n),扫描所有O(1),只通知有事件的
内存拷贝每次都要复制所有fd每次都要复制所有fd只复制就绪的fd
触发方式水平触发水平触发水平/边缘触发
内核支持所有系统所有系统仅Linux 2.6+
使用复杂度简单中等较复杂

现实场景比喻

场景:学校食堂打饭

Select方式:

  • 食堂阿姨每隔5分钟就大喊:“要打饭的同学举手!”
  • 所有人都要回应,不管饿不饿
  • 最多只能服务1024个学生

Poll方式:

  • 每个人发一张卡片,饿了就翻到"饿"的一面
  • 阿姨还是需要看所有人的卡片
  • 但可以服务全校学生

Epoll方式:

  • 安装智能系统,学生饿了按按钮
  • 系统只告诉阿姨哪些学生按了按钮
  • 阿姨直奔这些学生,效率最高

代码直观对比

// Select:查询1000个连接fd_set readfds;FD_ZERO(&readfds);for(i=0;i<1000;i++){FD_SET(fds[i],&readfds);// 所有连接加入集合}select(1001,&readfds,NULL,NULL,NULL);// 内核遍历1000个// 应用层再遍历1000个找就绪的// Poll:也是遍历1000个structpollfdfds[1000];poll(fds,1000,-1);// 内核遍历1000个// 应用层再遍历1000个// Epoll:只处理就绪的intepfd=epoll_create(1000);// 创建红黑树+就绪链表epoll_ctl(epfd,EPOLL_CTL_ADD,fd,&ev);// 注册到红黑树epoll_wait(epfd,events,1000,-1);// 只返回就绪的,可能就几个// 直接处理返回的几个events

核心机制图解

Select/Poll:

用户态 内核态 ↓ ↓ [1,2,3...1000] → 遍历所有 → [1,5,7] // 返回就绪的 ↑ ↑ 复制所有 复制就绪的

Epoll:

用户态 内核态 ↓ ↓ 注册fd到红黑树 → 等待事件 → 就绪链表 ← 事件发生 ↑ ↑ 只复制就绪fd 只检查就绪链表

选择建议

  1. 小型项目/跨平台:用Select(简单通用)
  2. 中型项目:用Poll(连接数多但并发不高)
  3. 高性能服务器:用Epoll(Linux下必备)
  4. Windows平台:用IOCP(Windows的"Epoll")
  5. Mac/BSD:用Kqueue(Unix的"Epoll")

一句话总结

  • Select:全村广播找人
  • Poll:点名册逐个点名
  • Epoll:微信通知,谁有事@你

就像从"挨家挨户敲门"进化到"手机智能推送",Epoll让服务器知道谁有事要处理,而不是盲目地问所有人有没有事

http://www.jsqmd.com/news/263001/

相关文章:

  • 【小程序毕设全套源码+文档】基于微信小程序的上门做菜预定服务平台设计与实现(丰富项目+远程调试+讲解+定制)
  • 深入解析:【JavaSE】十九、JVM运行流程 类加载Class Loading
  • 2026年求推荐靠谱的AI智能办公鼠标,南方网通鸿容鼠标别错过 - 工业品牌热点
  • Tops新年赛总结
  • VisionMaster之上下相机对位贴合
  • IPTools v5.0.8.3 专业 IP 地址修改与网卡配置工具
  • 总结2026年轴承老牌代理厂家,伯陆商城优势显著 - 工业品牌热点
  • 2026年苏州食材配送一站式服务保障排名,旺利涛食品实力上榜! - 工业品牌热点
  • 聊聊专业翻译企业,天使翻译公司质量保障与服务优势有哪些? - 工业品牌热点
  • 2026年市面上做得好的高架库企业排名,高架库/智能仓储/智能仓库/立体仓储/全自动仓库,高架库公司如何选 - 品牌推荐师
  • 2026必备!9个AI论文工具,专科生轻松搞定毕业论文!
  • 强烈安利!10个AI论文工具测评,本科生毕业论文必备
  • 1月17号和18号总结
  • 人生死机了?别慌,这是系统升级
  • 【参数优化】基于带动态边界 + 周期性重置 + 惯性权重衰减的粒子群优化三环自动驾驶仪设计二阶 高阶控制系统的双参数控制器附matlab代码
  • 解决局域网 NAS 远程桌面连接失败:火绒“误伤”排查实录
  • 树剖总结
  • Flutter 与开源鸿蒙(OpenHarmony)国际化、无障碍与合规开发实践:打造全球可用的可信应用 - 详解
  • Invicti Standard v26.1.0 for Windows - 企业级 Web 应用与 API 安全
  • 课题:PLC控制的变频电梯系统的设计(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • Comsol脉冲涡流无损检测仿真 图一:脉冲涡流仿真,检出电压信号 图二:脉冲涡流模型 图三:...
  • 哈希表的c++实现及其常用函数
  • 自动售货机(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • [Vulkan 实战] 深入解析 Dynamic Uniform Buffers:高效绘制多物体的利器
  • 基于PLC自动门控制系统设计(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 我国农产品标准化的对外贸易效应分析(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 互联网大厂Java求职面试实战:涵盖Spring Boot、微服务与AI技术的全栈问答
  • 基于MVC模式的在线书店的设计与实现(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 【气动学】基于短程攻击导弹的最短时间约束并解决策梅洛问题附Matlab代码和报告
  • 基于PHP的新闻发布系统的设计与开发(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码