阻塞/非阻塞 、 同步/异步

典型的一次IO的两个阶段是什么?数据准备/就绪(监听)和数据读写

阻塞的时候,线程会被处于挂起状态。如果有数据则返回,也可能出现错误返回-1;

非阻塞的时候,线程会执行,遇到recv会直接返回值,返回-1时,会出现errno错误,比如中断引起的EINTR、EAGAIN、EWOULDBLOCK。
同步表示A 向 B 请求调用一个网络 IO 接口时(或者调用某个业务逻辑 API 接口时),数据的读写都是 由请求方A 自己来完成的(不管是阻塞还是非阻塞);异步表示 A 向 B 请求调用一个网络 IO 接口时 (或者调用某个业务逻辑API 接口时), 向B传入请求的事件以及事件发生时通知的方式,A就可以处理其它逻辑了 ,当B 监听到事件处理完成后,会用事先约定好的通知方式,通知 A 处理结果。
在处理 IO 的时候,阻塞和非阻塞都是同步 IO,只有使用了特殊的 API 才是异步 IO。

  1. EINTR (Interrupted System Call):

    • 意义:系统调用被中断。
    • 发生情况:当进程收到信号时,可能会中断正在进行的系统调用。当信号处理程序执行完毕后,系统调用可能会返回这个错误码,表示调用被中断。程序员通常需要重新发起系统调用。
  2. EAGAIN (Resource temporarily unavailable):

    • 意义:资源暂时不可用。
    • 发生情况:在非阻塞I/O中,当操作无法立即完成(例如,读取或写入没有数据可用或缓冲区已满)时,系统调用可能返回 EAGAIN。这并不表示错误,而是指出应用程序应该稍后再次尝试。
  3. EWOULDBLOCK (Operation would block):

    • 意义:操作将会阻塞。
    • 发生情况:与 EAGAIN 类似,EWOULDBLOCK 也表示在非阻塞I/O中,操作无法立即完成,但这两个错误码在实际使用中通常是相同的。在许多系统中,EAGAIN 和 EWOULDBLOCK 被定义为相同的值。
相关推荐
wadesir1 分钟前
当前位置:首页 > 服务器技术 > 正文Linux网络HSRP协议(实现路由器热备份与高可用性的实用指南)
linux·服务器·网络
稻谷君W4 分钟前
Ubuntu 远程访问 Win11 WSL2 并固定访问教程
linux·运维·ubuntu
泡沫·4 分钟前
4.iSCSI 服务器
运维·服务器·数据库
胡八一8 分钟前
解决PHP未检测到您服务器环境的sqlite3数据库扩展报错
服务器·数据库·php
不解不惑18 分钟前
OpenAI whisper 语音识别服务器搭建
服务器·whisper·语音识别
gaize121327 分钟前
适合业务规模较大的场景的服务器测评
服务器
带土128 分钟前
4. 两台win11 笔记本局域网内文件传输
网络
wdfk_prog28 分钟前
[Linux]学习笔记系列 -- [kernel]workqueue
linux·笔记·学习
wdfk_prog30 分钟前
[Linux]学习笔记系列 -- [kernel]usermode_helper
linux·笔记·学习
weixin_4365250732 分钟前
使用 idea 命令行构建 Docker 镜像并部署到云服务器
linux·docker·github