IO多路复用的理解

  • IO:网络IO
  • 多路:多个链接
  • 复用:复用一个或多个线程
  • 在IO多路复用中,当一个线程在等待IO操作时,实际上是将该线程中的事件循环或IO轮询操作交给了操作系统内核 。这样的操作系统调用通常会将线程置于休眠状态,直到至少一个监视的IO事件就绪。此时,不会占用CPU资源,而是允许CPU去处理其他任务。

  • 当有一个或多个IO事件就绪时,操作系统会通知等待的线程 ,线程从休眠状态中唤醒,并处理就绪的IO事件。这种机制允许单个线程处理多个IO连接,提高了系统的效率和性能。因此,IO多路复用是一种高效的并发编程技术,特别适用于高并发的网络服务器应用,如Web服务器和数据库服务器等。

  • 总结:IO多路复用实现了线程的复用,而不是CPU内核的复用。这也是IO多路复用的一个主要优势之一:在一个线程中同时监视多个IO事件,而不需要为每个IO连接创建一个独立的线程。这样可以大大减少线程的创建和销毁开销,从而节省系统资源并提高并发处理能力。

相关推荐
运维老郭几秒前
【K8s 调度三阶段 · 避坑完全指南】过滤→打分→绑定,9 成 Pending 都卡在第一关
运维·云原生·kubernetes
keyipatience3 分钟前
Linux进程调度与优先级机制解析
linux·运维·服务器
IT大白鼠15 分钟前
Linux系统中应用程序安装及管理
linux·服务器
叶非花19 分钟前
Ubuntu服务器性能检测工具NetData安装
linux·服务器·ubuntu
在角落发呆21 分钟前
Windows 8系统下的IP转发:一台电脑如何变身网络桥梁
运维·服务器
许长安23 分钟前
RingBuffer:面向网络编程的环形缓冲区实现
服务器·网络·c++·经验分享·笔记·缓存
SPC的存折37 分钟前
14、K8S-NetworkPolicy
运维·云原生·容器·kubernetes
skd899938 分钟前
酒店总机永不占线解决方案-小蜜蜂多酒店系统配置说明
服务器·信息与通信
Splashtop高性能远程控制软件39 分钟前
切屏时代终结,Splashtop 统一 IT 运维平台助力 MSP 高效运营
运维·自动化·远程控制·splashtop
小此方40 分钟前
Re:Linux系统篇(十二)工具篇 · 四:make与Makefile:高效管理 C++ 工程项目构建
linux·运维·c++·开发工具