IO多路复用的理解

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

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

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

相关推荐
楼田莉子1 分钟前
Linux进程间通信——System V系列
linux·服务器·c++·学习·信息与通信
Percep_gan1 分钟前
禁用Linux默认端口监听IPv6地址,修改为监听IPv4
linux·运维·服务器
酣大智3 分钟前
传输介质-- 网线
运维·网络
云飞云共享云桌面3 分钟前
SolidWorks如何实现多人共享
服务器·前端·数据库·人工智能·3d
济6174 分钟前
linux 系统移植(第二十二期)---- 初步测试BusyBox构建的根文件系统---- Ubuntu20.04
linux·运维·服务器
h7ml5 分钟前
电商返利系统中佣金计算的幂等性保障与对账补偿机制实现
服务器·前端·php
资料库016 分钟前
Bond的模式都有哪些?
服务器·网络
boy快快长大7 分钟前
Docker简单服务迁移
运维·docker·容器
RisunJan19 分钟前
Linux命令-lha(压缩或解压缩lzh格式文件)
linux·运维·服务器
好好研究20 分钟前
MobaXterm远程连接云服务器(Centos环境)及配置jdk、Tomcat、MySQL环境
java·服务器·mysql·jdk·tomcat·aliyun服务器