IO多路复用的理解

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

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

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

相关推荐
人工智能训练7 分钟前
OpenEnler等Linux系统中安装git工具的方法
linux·运维·服务器·git·vscode·python·ubuntu
郭涤生40 分钟前
第十章_信号_《UNIX环境高级编程(第三版)》_笔记
服务器·笔记·unix
QT 小鲜肉1 小时前
【Linux命令大全】001.文件管理之which命令(实操篇)
linux·运维·服务器·前端·chrome·笔记
额呃呃1 小时前
select详细分析
服务器
网创联盟,知识导航1 小时前
沐雨云香港大宽带云服务器 · 配置全览
服务器·阿里云·腾讯云
fantasy5_52 小时前
Linux 动态进度条实战:从零掌握开发工具与核心原理
linux·运维·服务器
weixin_462446232 小时前
exo + tinygrad:Linux 节点设备能力自动探测(NVIDIA / AMD / CPU 安全兜底)
linux·运维·python·安全
不瘦80斤不改名2 小时前
Python 日志(logging)全解析
服务器·python·php
莫逸风3 小时前
【局域网服务方案】:无需找运营商,低成本拥有高性能服务器
运维·服务器
oMcLin3 小时前
CentOS 7 频繁出现 “Connection Refused” 错误的原因分析与解决
linux·运维·centos