核心区分:用户态/内核态切换 vs. 程序阻塞

核心区分:用户态/内核态切换 vs. 程序阻塞

关键点:

1、同步I/O操作一定会发生用户态到内核态的切换

  • 当应用程序发起I/O请求(如read(), write()系统调用)时,确实会从用户态切换到内核态
  • 内核处理I/O请求(准备数据、操作设备等)

2、但"等待I/O操作完成"不一定意味着"一直停留在内核态"

实际情况:
阻塞式同步I/O:

c 复制代码
// 示例:read()系统调用
bytes_read = read(fd, buffer, size);  // ① 用户态→内核态
                                     // ② 内核检查数据是否就绪
                                     // ③ 如果数据未就绪,当前线程被阻塞
                                     // ④ 内核将CPU调度给其他进程
                                     // ⑤ 数据就绪后,线程被唤醒,继续执行

此时线程/进程被挂起,但CPU已回到用户态执行其他进程

不是"一直停留在内核态等待"

非阻塞式同步I/O:

c 复制代码
fcntl(fd, F_SETFL, O_NONBLOCK);
bytes_read = read(fd, buffer, size);  // 立即返回,可能返回EAGAIN

正确的表述:

"同步I/O操作会阻塞调用线程直到I/O操作完成,但这期间CPU可能被调度执行其他任务,并不是一直停留在内核态。"

对比异步I/O:
真正的异步I/O(如Linux的io_uring,Windows的IOCP):

  • 发起I/O请求后立即返回
  • I/O完成后通过回调或信号通知
  • 等待期间完全不阻塞调用线程

总结表格:

I/O类型 用户态→内核态 等待期间状态 是否阻塞调用者
阻塞同步I/O 线程被挂起,CPU执行其他任务
非阻塞同步I/O 立即返回,轮询检查 否(但需主动检查)
异步I/O 完全不等待,回调通知
相关推荐
暮色_年华3 小时前
随想 2:对比 linux内核侵入式链表和 STL 非侵入链表
linux·c++·链表
w-w0w-w4 小时前
C++模板参数与特化全解析
开发语言·c++
大锦终4 小时前
递归回溯综合练习
c++·算法·深度优先
晚风吹长发5 小时前
初步了解Linux中的动静态库及其制作和使用
linux·运维·服务器·数据结构·c++·后端·算法
风之歌曲5 小时前
c++高精度模板
c++·算法·矩阵
crescent_悦6 小时前
C++:Find Coins
c++
嵌入式进阶行者6 小时前
【算法】深度优先搜索实例:华为OD机考双机位A卷- 中庸行者
c++·算法·华为od·深度优先
云深麋鹿6 小时前
C++入门篇
c++
量子炒饭大师7 小时前
【C++入门】零域终端的虚空指针协议——【nullptr】还在为编译器给NULL匹配为int而头疼?nullptr给予你全新的字面量!
开发语言·c++·nullptr
阿豪只会阿巴7 小时前
【多喝热水系列】从零开始的ROS2之旅——Day10 话题的订阅与发布1:Python
开发语言·c++·python·ubuntu·ros2