IO模型

作者: uangianlap | 来源:发表于2017-02-11 16:24 被阅读14次

IO的过程

一次IO都会有两个阶段:
❶ 等待数据,即数据从磁盘到内核内存.
❷ 复制数据,即数据从内核内存到进程内存.

5种IO模型

阻塞型         # 阻塞/非阻塞,关注的是调用结果返回前调用者的状态
非阻塞型
复用型
信号驱动型 
异步

阻塞型(block): .

调用结果返回之前,IO的两个阶段调用者被“挂”起.比如你去钓鱼,只是一直等着看,只到鱼上钩才处理.

非阻塞型(noblock)

调用结果返回之前,调用者不会被“挂”起。即IO第一阶段调用者是不会被阻塞的,但也是处于“盲”等待即无目的地等待(所以效率上未必强于阻塞型),只在第二阶段会被阻塞.比如你去钓鱼,放下鱼钩后你就在一旁玩手机或看书,只是偶尔才过去看一看鱼有没有上钩.

同步(sync)

调用者等待对方(被调用者 )返回消息

异步(async)

被调用者通过状态、通知或回调机制通知调用者被调用者的运行状态

复用型(多路输出)

select() 1024个限制 BSD
poll() sysv

信号驱动型

相关文章

  • 1.Nette入门第一章——IO演进

    1. IO 基础 1.1. linux网络IO模型 阻塞IO模型 非阻塞IO模型 IO多路复用模型(NIO) 信...

  • 细谈Select,Poll,Epoll

    阻塞 io 模型 blocking IO非阻塞 io 模型 nonblocking IOio多路复用模型 IO m...

  • 2.五种IO模型

    0.IO介绍1.阻塞IO模型2.非阻塞IO模型3.IO多路复用模型4.信号驱动IO模型5.异步IO模型6.五种IO...

  • 网络IO模型

    网络IO的模型大致包括下面几种 同步模型(synchronous IO)阻塞IO(bloking IO)非阻塞IO...

  • 「基础知识总结」 IO模型

    IO模型 五种IO模型包括:阻塞IO、非阻塞IO、信号驱动IO、IO多路转接、异步IO。其中,前四个被称为同步IO...

  • 五种 IO 模型

    五种 IO 模型 参考链接 一共有五种 IO 模型 阻塞 IO 非阻塞 IO 多路复用 IO 信号驱动 IO 异步...

  • Java中的IO模型

    Java中的IO模型 Java中的IO模型有四种: 同步阻塞IO 同步非阻塞IO IO多路复用 异步IO 其中IO...

  • 23、pythonIO模型

    python之路——IO模型 IO模型介绍 为了更好地了解IO模型,我们需要事先回顾下:同步、异步、阻塞、非阻塞 ...

  • IO模型

    IO模型 五种模型

  • 2018-07-03

    Netty实践与NIO原理 一、阻塞IO与非阻塞IO Linux网络IO模型(5种) (1)阻塞IO模型 所有文件...

网友评论

      本文标题:IO模型

      本文链接:https://www.haomeiwen.com/subject/zipeuttx.html