1: BIO是一种同步阻塞的通信模式,数据的读取写入必须阻塞在一个线程内等待其完成。是一个比较传统的通信方式,模式简单、使用方便,但并发处理能力低,通信耗时,依赖网速。
BIO适用于连接数目比较小且固定的架构,这种方式对服务器资源要求比较高,并发局限于应用 中,JDK1.4以前的唯一选择,但程序直观简单易理解
2: NIO(Non-Bock) IO 是一种同步非阻塞的通信模式,一个线程不断的轮询每个输入输出的状态改变,如果有状态发生了改变,则进行下一步的操作。针对网络传输效能优化的新功能。
NIO适用于连接数目比较多且连接比较短的架构,比如聊天服务器,并发局限于应用中,编程比较复杂,JDK1.4开始支持
3: AIO(Asynchronous IO)是一种异步非阻塞的通信模式。无需一个线程去轮询所有IO操作的状态改变,在相应的状态改变后,系 统会通知对应的线程来处理。
AIO方式适用于连接数目多且连接比较长的架构,比如相册服务器,充分调用OS参与并发操作,编 程比较复杂,JDK7开始支持。

9119

被折叠的 条评论
为什么被折叠?



