5张图看懂Unix/Linux中的同步IO和异步IO

前言

  在Linux系统中,一切皆为文件,任何对设备读写操作都可以认为是对文件句柄的读写操作。在对文件的读写过程中,一般需要用户态和内核态的相互切换,从而有了同步IO和异步IO。从定义上的区别是:同步IO操作导致请求进程阻塞,直到IO操作完成,而异步IO操作不导致请求进程阻塞。接下来,以UDP网络套接字编程中的recvfrom函数为例,了解一下Unix下的5种IO模型(阻塞IO、非阻塞IO、IO多路复用、信号驱动式IO以及异步IO)。

1、同步IO模型

1.1、阻塞IO和非阻塞IO

在这里插入图片描述

1.2、IO多路复用和信号驱动式IO

在这里插入图片描述

2、异步IO模型

在这里插入图片描述
注意:支持POSIX异步IO模型的系统比较罕见,不能确定这样的系统是否支持套接字上的这种模型

总结

  一个输入操作主要包括数据准备阶段数据拷贝阶段。阻塞IO、非阻塞IO、多路复用IO、信号驱动式IO都属于同步IO模型,它们虽然在数据准备阶段处理不同(有阻塞的也有不阻塞的),但在数据拷贝阶段相同,都需要阻塞等待数据拷贝完成,尽管拷贝数据期间的时间消耗是非常短。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值