BIO、NIO、NIO.2之间的区别主要是通过同步/异步、阻塞/非阻塞来进行区分的
同步:
程序与操作系统进行交互的时候采取的是问答的形式
异步:
程序与操作系统取得连接后,操作系统会主动通知程序消息
阻塞:
程序在执行一个操作的时候,在执行完毕前会一直等待
非阻塞:
程序在执行的时候,不会停止
举例:
对于Socket监听程序而言
BIO:同步阻塞
JDK1.4之前
不停地监听是否有新的连接,如果有新的连接,就使用流进行读写操作,在读写过程中程序是不能做其他事情的
对机器的性能要求较高
并发局限于应用
NIO:同步非阻塞
JDK1.4开始提供
不停地监听是否有新的连接,通过判断Socket是否为null来决定是否进行操作,只有Socket为null,才说明服务器收到了请求,但是这并不影响程序继续往下执行,如果程序想要在收到null的时候做其他事情,就可以继续往下执行。
适用于连接数目多,且连接操作时间较短的情况。如:聊天服务器。
并发局限于应用
NIO.2:异步非阻塞
JDK1.7开始提供
将事件与执行动作进行“绑定”,一旦产生了连接、读取等事件,系统会通知程序,程序收到通知后执行相关的操作
适用于连接数目多,且连接操作时间较长的情况。
并发过程中充分调用了OS