同步异步阻塞非阻塞

同步和异步 阻塞和非阻塞

阻塞非阻塞是调用后是否立即返回。

同步异步是针对两个对象,"请求发起者"和"请求处理者"。发起请求后怎么获得结果,是自己反复询问,还是等别人主动通知。

一次完整的网络读操作,分为两步,第一步内核等待数据,第二步内核将数据拷贝到用户空间。

内核等待网卡的数据,内核将网卡的数据写入内核缓冲区。

内核将从内核缓冲区中将网卡的数据拷贝到用户空间。

用户进行read,内核等待网卡的数据,然后将数据拷贝到用户空间,如果用户线程一直在等待,等待时"挂起",不做任何事情。这就是阻塞。

用户在read后会立即返回结果,然后不断轮询,直到数据拷贝到用户空间。这就是非阻塞。

在内核将数据拷贝到用户空间时,用户线程在等待拷贝完成,就是同步。

在内核将数据拷贝到用户空间时,用户线程不等待,拷贝完成后,内核通知用户已经拷贝完成。这就是异步。

一次完整的网络读操作,分为两步,第一步内核等待数据,第二步内核将数据拷贝到用户空间。

调用read,然后等待内核将数据拷贝到用户空间,期间用户一直等待,不做其他事情,就是同步阻塞。

调用read,然后立即返回一个结果,不管内核是否已经完成数据的拷贝,如果没有完成就返回一个错误,然后不断地询问,每次询问都会立即返回,直到拷贝完成,返回正确结果,就是同步非阻塞。

调用read,然后去做其他的事情,直到内核完成了数据拷贝,通知用户去处理数据。就是异步非阻塞。

异步一定是非阻塞,同步可能是阻塞也可能是非阻塞。

去食堂吃饭,分为两步,第一步厨师炒完菜,第二步服务员将菜算过来。

我点好菜后,等待厨师炒完菜,再等待服务员送过来,期间什么都不做。这就是同步阻塞。

我点好菜后,就去做其他的事情,然后每隔一段时间问一下,我的菜好了吗,直到服务员端上来。这就是同步非阻塞。

我点好菜后,就去做其他的事情,服务员把菜端上来后,通知我菜好了。这就是异步非阻塞。

一次完整的网络读操作,分为两步,第一步内核等待数据,第二步内核将数据拷贝到用户空间。

epoll其实是同步IO

复制代码
用户:调用epoll_wait → 阻塞等待【步骤1完成】
内核:步骤1完成(数据到内核缓冲区)
内核:唤醒epoll_wait,返回"可读"
用户:调用recv → 进入内核,执行【步骤2】(拷贝数据)
用户:等待recv返回(拷贝完成)
用户:拿到数据

用户等待了步骤1(在epoll_wait里) 也 等待了步骤2(在recv里)。 所以是同步。

io_uring 才是异步

复制代码
用户:调用io_uring_enter,提交读请求 → 立即返回(不等待)
内核:【步骤1 + 步骤2】全权负责
     - 等待数据到达
     - 自动拷贝数据到用户指定的内存
内核:全部完成后,在完成队列里放一个完成事件
用户:稍后调用io_uring_enter(或轮询)检查完成事件
用户:发现完成事件,直接使用数据(无需再调用recv)

用户没有等待步骤1,也没有等待步骤2。全由内核干完。所以是异步。

相关推荐
江湖有缘2 小时前
实时监控所有端口,Docker 部署 WatchYourPorts 保姆级教程
运维·docker·容器
Cyber4K2 小时前
【DevOps专项】Git 部署及使用方法
运维·git·devops
数据雕塑家2 小时前
Linux磁盘性能测试完全指南:使用FIO深入评估存储系统
linux·运维·服务器
csdn_aspnet2 小时前
告别重复造轮子:Codex写脚本,运维/DevOps场景下,用Codex批量生成Shell/Python自动化脚本
运维·python·ai·自动化·devops·codex·辅助编程
positive_zpc2 小时前
计算机网络——数据链路层(二)
服务器·网络·计算机网络
木心术12 小时前
DevOps全流程实践:从CI/CD到自动化测试的最佳实践
运维·ci/cd·devops
一直会游泳的小猫2 小时前
Homebrew - macOS 与 Linux 的包管理器
linux·运维·macos·brew·包管理工具
开开心心_Every2 小时前
文件强制删除工具,单文件拖入解锁删除简单
运维·edge·pdf·计算机外设·逻辑回归·散列表·启发式算法
halazi1002 小时前
WSL 安装与 Ubuntu 24.04 配置使用指南
linux·运维·ubuntu·wsl