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

典型的一次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 被定义为相同的值。
相关推荐
SPC的存折3 分钟前
1、MySQL故障排查与运维案例
linux·运维·服务器·数据库·mysql
Run_Teenage4 分钟前
Linux:认识信号,理解信号的产生和处理
linux·运维·算法
Deitymoon16 分钟前
linux——TCP服务器获取客户端IP地址
linux·服务器·tcp/ip
CDN36018 分钟前
高防服务器磁盘 / CPU 爆满?攻击引流与资源扩容实战
运维·服务器·网络协议
小贾要学习19 分钟前
【Linux】应用层自定义协议与序列化
linux·服务器·c++·json
white-persist21 分钟前
【vulhub spring CVE-2018-1270】CVE-2018-1270 Spring Messaging 远程命令执行漏洞 完整复现详细分析解释
java·服务器·网络·数据库·后端·python·spring
听到微笑23 分钟前
MCP传输协议演进:从SSE到Streamable HTTP
网络·网络协议·http
Amnesia0_025 分钟前
理解Linux中的OS管理和进程属性
linux·运维·服务器
十五年专注C++开发25 分钟前
cpolar(极点云): 一款主流的内网穿透工具
linux·windows·cpolar·穿透
徒 花26 分钟前
HCIP学习05 链路聚合(Eth-Trunk)+ VRRP
服务器·网络·学习·hcip