Linux下的五种I/O模型
堵塞I/O(blocking I/O)
非堵塞I/O (nonblocking I/O)
I/O复用(select 和poll) (I/O multiplexing)
信号驱动I/O (signal driven I/O (SIGIO))
异步I/O (asynchronous I/O (the POSIX aio_functions))
前四种都是同步。仅仅有最后一种才是异步IO。
I/O过程分为两个过程,数据准备和数据拷贝
堵塞I/O模型:
该模型在两个过程中一直处于堵塞状态,直到数据拷贝完毕,系统调用返回.
堵塞I/O模型图:

当调用recv()函数时,系统首先查是否有准备好的数据。
假设数据没有准备好,那么系统就处于等待状态。
当数据准备好后。将数据从系统缓冲区拷贝到用户空间。然后该函数返回。
在套接应用程序中。当调用recv()函数时。未必用户空间就已经存在数据,那么此时recv()函数就会处于等待状态。
非堵塞IO模型
我们把一个SOCKET接口设置为非堵塞就是告诉内核,当所请求的I/O操作无法完毕时,不要将进程睡眠。而是返回一个错误。
这样我们的I/O操作函数将不断的測试数据是否已经准备好。假设没有准备好。继续測试,直到数据准备好为止。在这个不断測试的过程中。会耗费大量的占用CPU的时间。
有点类似于轮询
非堵塞I/O模型图:

IO复用模型:
I/O复用模型经常使用的函数有select、poll和epoll,详细的差别请查阅相关文档。
这几个函数也会使进程堵塞(请注意和I/O堵塞进行区分)该函数能够监听多个socket,看是否有socket就绪。假设就绪就返回就绪的socket数(或者超时返回)。然后对就绪的socket依照相应的就绪事件进行相关的操作(读数据或者写数据)
I/O复用模型图:

信号驱动IO
首先我们同意套接口进行信号驱动I/O,并安装一个信号处理函数,进程继续执行并不堵塞。
当数据准备好时。进程会收到一个SIGIO信号,我们能够在信号处理函数中调用I/O操作函数处理数据。

异步IO模型
当一个异步过程调用发出后,调用者不能立马得到结果。实际处理这个调用的模块在完毕I/O操作后。通过状态或者回调来通知调用者

同步IO和异步IO的差别:数据拷贝的过程中,进程是否堵塞!
堵塞IO和非堵塞IO的差别:数据准备的过程中,进程是否堵塞!
5种I/O模型的比較:

Linux下的五种I/O模型的更多相关文章
- []转帖] 浅谈Linux下的五种I/O模型
浅谈Linux下的五种I/O模型 https://www.cnblogs.com/chy2055/p/5220793.html 一.关于I/O模型的引出 我们都知道,为了OS的安全性等的考虑,进程是 ...
- 浅谈Linux下的五种I/O模型 两篇别人的博客
http://blog.csdn.net/sinat_34990639/article/details/52778562 http://www.cnblogs.com/chy2055/p/5220 ...
- 浅谈Linux下的五种I/O模型
一.关于I/O模型的引出 我们都知道,为了OS的安全性等的考虑,进程是无法直接操作I/O设备的,其必须通过系统调用请求内核来协助完成I/O动作,而内核会为每个I/O设备维护一个buffer.如下图所 ...
- Linux下的5种I/O模型(转)
Linux下的五种I/O模型: l 阻塞I/O l 非阻塞I/O l I/O复用(select.poll.epoll) l 信号驱动I/ ...
- Linux 下的五种 IO 模型
概念说明 用户空间与内核空间 现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32次方).操作系统的核心是内核,独立于普通的应用程序,可以访问受保护的 ...
- Linux下的5种I/O模型与3组I/O复用
引言 上一篇文章中介绍了一些无缓冲文件I/O函数,但应该什么时机调用这些函数,调用这些I/O函数时进程和内核的行为如何,如何高效率地实现I/O?这篇文章就来谈一谈Linux下的5种I/O模型,以及高性 ...
- Linux五种I/O模型性能分析
转载自:http://blog.csdn.net/jay900323/article/details/18141217/ socket阻塞与非阻塞,同步与异步 作者:huangguisu 1. 概念理 ...
- Unix下 五种 I/O模型
Unix下共有五种I/O模型: 1. 阻塞式I/O 2. 非阻塞式I/O 3. I/O复用(select和poll) 4. 信号驱动式I/O(SIGIO) 5. 异步I/O(POSIX的aio ...
- Linux 中的五种 IO 模型
Linux 中的五种 IO 模型 在正式开始讲Linux IO模型前,比如:同步IO和异步IO,阻塞IO和非阻塞IO分别是什么,到底有什么区别?不同的人在不同的上下文下给出的答案是不同的.所以先限定一 ...
随机推荐
- 关于函数提升在if语句中的表现
函数声明创建的函数在现代浏览器,在if语句中函数的声明不会提升,但是在老的IE版本中,if语句中的函数声明会提升 函数表达式在不同浏览器中函数声明都不会被提升,解决了不同浏览器的兼容性问题 关于函数提 ...
- 【poj1995】快速幂
题目大意 求a^b %p 1≤a,b,p≤10^9 思路 时间O(10^9)一定会爆T,采用数学方法+位运算,得到O(log b)的快速幂算法 代码 #include<cstdio> #i ...
- golang struct里面的字段,或者slice排序
accounts := []users.Account{}Admin.DB.Preload("CurrencyObj").Where("member_id = ?&quo ...
- Cracking the Coding Interview 4.8
You are given a binary tree in which each node contains a value. Design an algorithm to print all pa ...
- Spring Boot (14) 数据源配置原理
数据源配置源码 这里截取org.springframework.boot.autoconfigure.jdbc.DataSourceConfiguration的部分源码,主要介绍Tomcat和Hika ...
- 手动触发dom节点事件代码
在爬代码过程中,碰到一个稀奇古怪的问题.需要手工修改select的值,然后手动触发select的change事件,但使用网络上查到的通过trigger.onchange()事件触发都不执行,没办法,只 ...
- Haar、pico、npd、dlib等多种人脸检测特征及算法结果比较
原文:opencv.pico.npd.dlib.face++等多种人脸检测算法结果比较 NDP检测结果: 结果分析: Pico(Pixel Intensity Comparison-based Obj ...
- printf 打印较长字符
- 记录:通过SSH远程连接Ubuntu
一.安装openssh服务器 $ sudo apt-get install openssh-server 二.启动ssh服务 安装完成后,启动服务: $ sudo /etc/init.d/ssh st ...
- vue 导航菜单默认子路由
export default new Router({ routes: [ { path: '/', name: 'index', component: index, children: [ { pa ...