JavaNIO基础
-
BIO BlockingIO 同步阻塞
-
NIO NewIO/Non-Blocking IO 同步非阻塞
-
AIO Asychronous IO 异步非阻塞
-
同步
- 当A任务(银行业务)依赖B任务(排队),B任务完成 => A任务才完成。要么都成功,要么都失败。
-
异步
- 当A任务依赖B任务,通知B任务开发启动,A任务完成,即为完成。相对不可靠。
-
阻塞
- 面向CPU,等待慢操作完成才切换
-
非阻塞
- 面向CPU,在慢操作执行时,去做别的事,等操作完成后切换回来
-
无论是同步还是异步都可以出现阻塞和非阻塞
-
异步通过消息通知进制。同步没有消息通知,在银行排队办理业务的例子中,需要一直排队等待,时刻观察,异步有通知,并且是主动通知,无需一直等待,时刻观察。 阻塞和非阻塞是等待消息通知的一种状态。是否可以做其它事情。
-
同步和异步,关注的是消息通知的机制。阻塞和非阻塞,关注的是等待消息过程中的状态。
-
异步往往是非阻塞的。