同步异步阻塞非阻塞

同步和异步 阻塞和非阻塞

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

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

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

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

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

用户进行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。全由内核干完。所以是异步。

相关推荐
峥无3 小时前
Linux进程信号:从基础概念到内核底层原理
linux·运维·服务器·信号处理
广州灵眸科技有限公司3 小时前
瑞芯微RV1126B开发板(EASY-EAI-PI2) 开发(编译)方式说明
linux·服务器·单片机·嵌入式硬件·电脑
土星云SaturnCloud3 小时前
土星云AI边缘计算SE110S系列模型部署实战-YOLOv5
服务器·人工智能·yolo·docker·边缘计算
北山有鸟3 小时前
用开发板的.config替换ubuntu中内核源码目录的.config
linux·运维·ubuntu
qq_452396234 小时前
第二十篇:《Docker 故障排查常用命令与技巧》
运维·docker·容器
jcbut4 小时前
离线安装dify 1.7
linux·运维·dify
艾iYYY4 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
cjp5604 小时前
003.LINQ在WEB API中的应用
服务器·linq
云计算磊哥@4 小时前
运维开发宝典024-Linux云计算运维入门阶段总结
linux·运维·运维开发
周小码4 小时前
10分钟搭建私有Git服务器:Soft Serve实战
运维·服务器·git