I/O多路复用是系统级技术,通过select、poll、epoll实现单线程监控多socket;select跨平台但低效,poll无fd数量限制但仍O(n),epoll为Linux高效方案,支持ET/LT模式及近O(1)就绪通知;C++推荐用Boost.Asio等封装库。

I/O多路复用是C++(更准确说是系统级网络编程)中一种让单个线程/进程同时监控多个文件描述符(如socket)是否就绪(可读、可写、出错)的技术。它不等于C++标准库的iostream,而是底层基于操作系统提供的系统调用(select、poll、epoll),常用于实现高性能并发服务器(比如用C++写的HTTP服务、游戏网关等)。
原理是把一组fd(文件描述符)拷贝到内核,内核轮询检查它们的状态,任一就绪就返回,并修改用户传入的fd_set标记哪些就绪了。
缺点明显:每次调用都要拷贝整个fd集合、内核需遍历所有fd(O(n))、最大fd数量受限(通常1024)、无法告知具体哪个fd就绪(得自己遍历查)。
使用要点:
fd_set(用FD_ZERO和FD_SET)FOPEN_MAX或系统限制,且最大值要传给select()作为第一个参数用struct pollfd数组替代fd_set,内核直接遍历该数组。不再有1024限制,也不需要计算最大fd,但仍是O(n)遍历,每次仍要传全部fd数组,内核态/用户态间仍有数据拷贝。
立即学习“C++免费学习笔记(深入)”;
注意点:
pollfd.revents是输出字段,表示实际发生的事件;events是输入字段,指定关心哪些事件核心思想是“事件注册 + 就绪队列”。先用epoll_create创建一个内核事件表,再用epoll_ctl增删改监听项(每个fd只注册一次),最后用epoll_wait等待就绪事件——它只返回真正就绪的fd列表,时间复杂度接近O(1)(就绪数)。
关键优势:
典型用法:创建epoll fd → 设置socket为非阻塞 → epoll_ctl(EPOLL_CTL_ADD)注册 → 循环epoll_wait → 对每个就绪fd处理读写(ET下必须循环recv/send直到EAGAIN)。
实际项目中,不建议手撸select/poll/epoll封装。推荐:
libevent、libev、Boost.Asio(跨平台,内部自动选最优机制)io_context + async_accept/async_read,底层自动在Linux用epoll,macOS用kqueue,Windows用IOCP基本上就这些。选哪个不是看名字多酷,而是看你的目标平台、连接规模、维护成本——小工具用select也够用,万级并发服务必须上epoll或Asio。
以上就是c++++中的I/O多路复用是什么_c++ select/poll/epoll原理与使用【网络编程】的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号