BIO和NIO

BIO:同步阻塞式IO,服务器实现模式为一个链接一个线程,即客户端有链接请求时服务器端就须要启动一个线程进行处理,若是这个链接不作任何事情会形成没必要要的线程开销,固然能够经过线程池机制改善。 html


NIO(事件驱动):同步非阻塞式IO,服务器实现模式为一个请求一个线程,即客户端发送的链接请求都会注册到多路复用器上,多路复用器轮询到链接有I/O请求时才启动一个线程进行处理。 java


AIO(NIO.2):异步非阻塞式IO,服务器实现模式为一个有效请求一个线程,客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理。 服务器

各自应用场景 并发

到这里你也许已经发现,一旦有请求到来(无论是几个同时到仍是只有一个到),都会调用对应IO处理函数处理,因此:异步

(1)NIO适合处理链接数目特别多,可是链接比较短(轻操做)的场景,Jetty,Mina,ZooKeeper等都是基于java nio实现。函数

(2)BIO方式适用于链接数目比较小且固定的场景,这种方式对服务器资源要求比较高,并发局限于应用中。spa

参考:https://www.cnblogs.com/zedosu/p/6666984.html线程

银行职员故事讲解:http://blog.jobbole.com/88984/htm

相关文章
相关标签/搜索