1. I/O多路复用
1.1 流
流:
一个流可以是文件,socket,pipe等等可以进行I/O操作的内核对象。
不管是文件,还是套接字(Socket),还是管道(包括匿名和有名管道),我们都可以把他们看作流。
通过read,我们可以从流中读入数据;
通过write,我们可以往流写入数据。
以上面的流的定义为假设,我们需要从流中读数据,但此时,流中还没有数据,
(典型的例子为,客户端要从socket读如数据,但是服务器还没有把数据传回来),
这时候该怎么办?
可以有下面两种办法处理:
> 阻塞:
阻塞是个什么概念呢?
比如某个时候你在等快递,但是你不知道快递什么时候过来,而且你没有别的事可以干(或者说接下来的事要等快递来了才能做);
那么你可以去睡觉了,因为你知道快递把货送来时一定会给你打个电话(假定一定能叫醒你)。
> 非阻塞忙轮询:
接着上面等快递的例子,如果用忙轮询的方法,那么