首先看看下面几篇文章
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。