linux下 IO 阻塞 非阻塞

本文详细解析了Linux下的IO操作,包括阻塞IO和非阻塞IO的区别,同步IO与异步IO的定义,以及IO复用(如select、poll、epoll)的概念和优势。特别是epoll的ET模式,它以更高的效率降低重复事件的触发。
摘要由CSDN通过智能技术生成

1.区分堵塞、非堵塞
在一个IO操作过程中,以read为例,会涉及到两个过程:
1.等待数据准备好;
2.将数据从内核拷贝到进程中
这两个阶段是否发生阻塞,将产生不同的效果。

堵塞IO:
进程在请求read阻塞io的数据时,操作需要彻底完成后才返回到用户空间

非堵塞IO:
进程在步骤1不堵塞,如果数据没准备好,read(io操作)函数会立即返回一个状态值反馈给进程,所以对于非阻塞io,可以用一个while循环嵌套read来保证数据被读取。

2.区分同步、异步
同步IO
举个例子,同步IO在执行read函数时,如果有数据可读,进程会等待read函数执行完毕后继续执行接下去的代码。从这个层次来,阻塞IO、非阻塞IO操作、IO多路复用都是同步IO。

异步IO
异步IO操作不会导致请求的进程被blocked。当发出read请求,直接返回,等待read完成后,再通过返回值通知调用进程。

3.IO复用的定义及作用
I/O多路复用是通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作。常见的IO复用模型有select、poll、epoll三种,IO复用是一种同步IO。</

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员乐逍遥

如果你觉得帮助了你,支持一下!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值