Linux网络编程---5种I/O模型

2021/8/4 7:07:10

本文主要是介绍Linux网络编程---5种I/O模型,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

5种I/O模型

  • 1. 阻塞I/O
  • 2. 非阻塞I/O(忙等待)
  • 3. I/O复用(select和poll)
  • 信号驱动I/O
  • 异步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网络编程---5种I/O模型的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程