一、基础概念
IO操作分为两步:1.发起IO请求;2.执行具体IO操作;
同步和异步的区别是数据访问时进程是否阻塞或者说在执行真正IO操作时,数据能够立即返回就是异步,否则就是同步,同步和异步发生在IO第二个阶段;
同步和异步的区别在于多个任务和事件发生时,一个事件的发生或执行是否会导致整个流程的暂时等待。
阻塞和非阻塞的区别是应用程序发起IO请求能够被立即返回的就是非阻塞的,不能立即返回的就是阻塞的,阻塞非阻塞发生在IO的第一个阶段;
阻塞和非阻塞的区别关键在于当发出请求一个操作时,如果条件不满足是会一直等待还是返回一个标志信息。就好比我派一个人去做件事,在还没完成前,他会向我反馈任务还没完成,这个是非阻塞;还有一种就是只有等任务完成或者他死了(调用超时)才会给我反馈反馈(请求被挂起)。
二、BIO
BIO就是Block IO,缺点是一个请求开一个线程,请求多了服务器必挂
三、NIO(Non-Block IO)
四、IO多数复用:IO多路复用采用Selector来监控多个channel注册的事件,一旦事件就绪,Selector就去通知事件对应的channel。
五、AIO(异步IO)
比较好的参考文档:
1. https://www.cnblogs.com/dolphin0520/p/3916526.html
2. https://blog.csdn.net/hguisu/article/details/7453390