news 2026/4/18 5:26:22

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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让服务器知道谁有事要处理,而不是盲目地问所有人有没有事

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 3:28:10

2026国产时序数据库全景图:多模融合破局,企业选型实战指南

2026国产时序数据库全景图&#xff1a;多模融合破局&#xff0c;企业选型实战指南 摘要&#xff1a;进入2026年&#xff0c;在“数字中国”与工业物联网浪潮的强劲推动下&#xff0c;国产时序数据库市场持续繁荣&#xff0c;竞争格局日趋清晰。本文将对当前主流的国产时序数据库…

作者头像 李华
网站建设 2026/4/17 21:30:58

【开题答辩全过程】以 基于SSM框架的药店管理系统的设计与开发为例,包含答辩的问题和答案

个人简介 一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等 开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。 感谢大家…

作者头像 李华
网站建设 2026/4/18 3:30:49

基于VUE的编程兴趣班管理系统[VUE]-计算机毕业设计源码+LW文档

摘要&#xff1a;随着编程教育在青少年群体中的日益普及&#xff0c;编程兴趣班数量不断增多&#xff0c;传统的管理方式已难以满足高效运营的需求。本文旨在设计并实现一个基于VUE的编程兴趣班管理系统&#xff0c;利用前后端分离架构提升系统的灵活性与可维护性。前端采用VUE…

作者头像 李华
网站建设 2026/4/18 3:31:43

Nginx 配置示例及核心模块详解

Nginx 配置详解 一、配置文件结构 # 全局块&#xff08;主配置&#xff09; main# 事件块 events {... }# HTTP 块 http {# HTTP 全局配置...# 虚拟主机块&#xff08;一个或多个&#xff09;server {# 服务器配置...# 位置块&#xff08;一个或多个&#xff09;location {...}…

作者头像 李华
网站建设 2026/4/18 3:36:00

低成本高可用:充电桩平台在云原生(K8s)上的部署与运维实践

一、简述SpringBoot 框架&#xff0c;充电桩平台充电桩系统充电平台充电桩互联互通协议云快充协议1.5新能源汽车电动自行车公交车-四轮车充电充电源代码充电平台源码Java源码无加密项目二、介绍云快充协议云快充1.5协议云快充协议开源代码云快充底层协议云快充桩直连桩直连协议…

作者头像 李华