5种I/O模型

1. 阻塞I/O

一旦完成套接口连接后,就会向系统提交recv请求,这个请求是阻塞的,直到对方发送了数据填充套接口缓存,才解除阻塞。接收到数据后,从套接口缓存中复制数据到用户空间进行处理。
在这里插入图片描述

2. 非阻塞I/O(忙等待)

主要将文件描述符(套接字 )设置为非阻塞模式,即使没有数据到来,recv也不是阻塞的,会直接返回,直到有数据到来。但是这种模型很少用,因为在数据没有到来之前,会一直循环接收(没有接收到数据就会返回错误码),直到数据到来,这会造成cpu资源的浪费,被称为忙等待,
在这里插入图片描述

3. I/O复用(select和poll)

核心思想是用select管理多个文件描述符,有事件发生select就返回
在这里插入图片描述

信号驱动I/O

当有数据到来时,以信号的方式通知应用进程,因此也不会阻塞
在这里插入图片描述


异步I/O

这种模型效率最高,用aio\_read()函数来实现。该函数提交一个请求,并会提交一个buf,没有数据时该函数会立即返回,不影响应用程序处理其他任务。当有数据时就通过信号来通知应用程序。与信号处理IO模型不同的时,异步IO模型收到信号时,实际上数据已经由内核空间复制到用户空间了。也就是说,当内核收到数据时,该模型会主动将数据从内核空间复制到用户空间
在这里插入图片描述

标签: Linux, 编程, 模型, 数据, 阻塞, select, 异步, 到来

相关文章推荐

添加新评论,含*的栏目为必填