IO模型的简单记录select、poll、epoll

首先看看下面几篇文章

https://my.oschina.net/dclink/blog/287198

http://www.jb51.net/article/37416.htm

个人理解:

阻塞就是单个进程一直等待做一个事情,就算没有数据自己休眠也还是等待。

非阻塞就是这个事情没事可做的时候不管了,去做其他的事情了。那万一有事可做呢?还有不做这个事情的时候那它在做什么?这下就引出我们的非阻塞轮询模式了。

而非阻塞轮询中又有(select、poll、epoll)这些概念。

【select和poll其实相似】缓冲区满,缓冲区非空、缓冲区空事件都在一起,不管哪个事件发生,都要自己再遍历一遍。

【epoll多了一个事件event】比如10个IO,有三个缓冲区满了,需要客户端读取,我就能准确的知道哪三个满了,直接处理就行


这个文章讲解的也不错

http://www.cnblogs.com/Anker/p/3265058.html


有一句话比较重要:【我们这里讨论的阻塞什么都是基于内核空间和用户空间的。不是发生在“上层应用程序”的】

对于一次IO访问(以read举例),数据会先被拷贝到操作系统内核的缓冲区中,然后才会从操作系统内核的缓冲区拷贝到应用程序的地址空间。所以说,当一个read操作发生时,它会经历两个阶段:
1. 等待数据准备 (Waiting for the data to be ready)
2. 将数据从内核拷贝到进程中 (Copying the data from the kernel to the process)

正式因为这两个阶段,linux系统产生了下面五种网络模式的方案。
- 阻塞 I/O(blocking IO)
- 非阻塞 I/O(nonblocking IO)
- I/O 多路复用( IO multiplexing)
- 信号驱动 I/O( signal driven IO)
- 异步 I/O(asynchronous IO)

注:由于signal driven IO在实际中并不常用,所以我这只提及剩下的四种IO Model。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值