Blocking I/O Model
![](https://i-blog.csdnimg.cn/blog_migrate/6ec804f413c8f3c76160def5d33d54d3.jpeg)
阻塞模式 最简单的模式 函数一直等着直到有数据过来 基本上IO操作都会用一个Work Thread来进行
Nonblocking I/O Model
![](https://i-blog.csdnimg.cn/blog_migrate/a9bd170bf356111f5ca03c3185435f53.jpeg)
非阻塞模式 不停的查询是否有数据传来 并进行操作
I/O Multiplexing Model
![](https://i-blog.csdnimg.cn/blog_migrate/73a99202107495ee78ef5595e6777921.jpeg)
![](https://i-blog.csdnimg.cn/blog_migrate/0ad1f4d80bf9e79f8bcab543051febfe.jpeg)
信号驱动模式 注册信号及处理函数后 等待IO信号产生 我们可以在信号的handler 里面处理数据也可以在主程序里面处理这些数据
Asynchronous I/O Model
![](https://i-blog.csdnimg.cn/blog_migrate/5ea76eaeb32b4aee252bacf7e29de45a.jpeg)
异步IO: 这个模式是由用户程序告诉内核 自己处理IO操作。然后等到所有的操作都进行完毕后通知用户程序去取数据。这个操作和信号驱动的区别就是:异步模式等操作完毕后才通知用户程序而信号驱动模式在数据到来时就通知用户程序。
Comparison of the I/O Models
![](https://i-blog.csdnimg.cn/blog_migrate/0ed8f4823159a5d63061d916f1485210.jpeg)
前四个模式都是同步的,只有异步模式才是异步的
补充一个 WinSock的信息驱动模式,根据我的感觉呃 它有点像信息驱动模式。当信号来到后,处理的句柄发出相关的Windows信息。
用四个同步模式也可以模拟异步的模式: 当数据来时用一个thread来处理这些数据,当数据处理完毕之后再给主线程发送一条消息。 这样也是当数据处理完毕後主线程来进行处理的一种方法吧 呵呵。