阻塞和非阻塞、同步和异步(网络IO)

典型的一次IO的两个阶段是什么?数据就绪 和 数据读写。
数据就绪:根据 系统IO操作的就绪状态
        阻塞
        非阻塞
数据读写:根据 应用程序和内核的交互方式
        同步
        异步
陈硕:处理 IO 的时候, 阻塞和非阻塞都是同步 IO,只有使用了 特殊的 API 才是 异步 IO

 异步是操作系统将数据放到buf中的,同步是TCP接收缓冲区放入buf中的。通过异步IO接口将sockfd,buf,通知方式传给操作系统,并没有像同步一样从内核缓冲区中读取数据。

在使用异步 I/O 接口(如 aio_* 系列函数)发起异步 I/O 操作时,确实是通过 struct aiocb 结构体中的 aio_sigevent 成员将通知方式传递给操作系统的。开发者在准备好 struct aiocb 结构体时,会在其中设置 aio_sigevent 成员来确定通知方式,例如 SIGEV_SIGNALSIGEV_NONESIGEV_THREAD

具体的通知方式取决于使用的异步 I/O 接口和实现。例如,aio_* 系列函数通常使用信号来通知异步 I/O 操作完成,而在事件驱动的异步 I/O 模型中,通常会使用事件回调函数来处理完成的事件。

总结:
一个典型的网络IO接口调用,分为两个阶段,分别是“数据就绪” 和 “数据读写”,数据就绪阶段分为
阻塞和非阻塞,表现得结果就是, 阻塞当前线程或是直接返回
同步表示A向B请求调用一个网络IO接口时(或者调用某个业务逻辑API接口时),数据的读写都是
由请求方A自己来完成的(不管是阻塞还是非阻塞);异步表示 A向B请求调用一个网络IO接口时
(或者调用某个业务逻辑API接口时), 向B传入请求的事件以及事件发生时通知的方式A就可以
处理其它逻辑了,当 B监听到事件处理完成后,会 用事先约定好的通知方式,通知A处理结果

类型: 

同步阻塞
同步非阻塞
异步阻塞
异步非阻塞

相关推荐

  1. 高级IO——阻塞IOselect

    2024-01-30 16:46:02       16 阅读
  2. Verilog 14: 阻塞阻塞赋值的异同

    2024-01-30 16:46:02       27 阅读
  3. 阻塞异步

    2024-01-30 16:46:02       17 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-30 16:46:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-30 16:46:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-30 16:46:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-30 16:46:02       18 阅读

热门阅读

  1. QT 之信号槽

    2024-01-30 16:46:02       36 阅读
  2. OpenAI Gym 中级教程——环境定制与创建

    2024-01-30 16:46:02       29 阅读
  3. html css实现钟表简单移动

    2024-01-30 16:46:02       47 阅读
  4. 《设计模式的艺术》笔记 - 模板方法模式

    2024-01-30 16:46:02       38 阅读
  5. oracle版本号中的i,G,C代表什么含义

    2024-01-30 16:46:02       41 阅读
  6. Vscode移植到VS2010遇到的问题C++

    2024-01-30 16:46:02       38 阅读
  7. C++发起Https请求

    2024-01-30 16:46:02       31 阅读
  8. Pull模式和Push模式

    2024-01-30 16:46:02       39 阅读