A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© lais 中级黑马   /  2019-3-26 14:47  /  884 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 lais 于 2019-3-26 15:20 编辑

NIO、BIO、AIO区别

在学习Java I/O类库时,容易混淆NIO、BIO、AIO这几个概念,同时对于阻塞和非阻塞、同步和异步的理解也较为晦涩,这篇文章是对这几个概念的一些区分以及个人的一些见解.

一、同步阻塞I/O(BIO)

同步阻塞I/O,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销,可以通过线程池机制来改善。BIO方式适用于连接数目比较小且固定的架构,这种方式对服务端资源要求比较高,并发局限于应用中,在jdk1.4以前是唯一的io现在,但程序直观简单易理解
       二、同步非阻塞I/O(NIO)
       同步非阻塞I/O,服务器实现模式为一个请求一个线程,即客户端发送的连接请求都会注册到多路复用器上,多路复用器轮询到连接有IO请求时才启动一个线程进行处理。NIO方式适用于连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,并发局限于应用中,编程比较复杂,jdk1,4开始支持
       三、异步非阻塞I/O(AIO)
       异步非阻塞I/O,服务器实现模式为一个有效请求一个线程,客户端的IO请求都是由操作系统先完成了再通知服务器用其启动线程进行处理。AIO方式适用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,jdk1.7开始支持。
      四、IO与NIO区别

IO面向流,NIO面向缓冲区、IO的各种流是阻塞的,NIO是非阻塞模式。

      Java NIO的选择允许一个单独的线程来监视多个输入通道,可以注册多个通道使用一个选择器,然后使用一个单独的线程来“选择”通道:这些通道里已经有可以处理的输入或选择已准备写入的通道。这种选择机制,使得一个单独的线程很容易来管理多个通道
      五、同步与异步的区别
      同步:发送一个请求,等待返回,再发送下一个请求,同步可以避免出现死锁,脏读的发生
      异步:发送一个请求,不等待返回,随时可以再发送下一个请求,可以提高效率,保证并发

  作者:Vechace
  链接:https://www.jianshu.com/p/a660c17bb9ea
       来源:简书









2 个回复

倒序浏览
香港作为世界三大金融中心之一,经济形势已经经过爆发式发展的时期,如今的香港,经济贸易依然处于领先位置,并且在不断地平稳发展。而之所以有那么多人认为香港的经济形势不乐观,主要是因为近几年国内的发展势头太过迅猛,尤其是房地产这一块,两相对比之下,香港平稳的发展才不那么显眼。为吸引相关世界各地人才来港,我们将通过“优秀人才入境计划”按现时年度1000的配额,为人才清单下合资格人士提供入境便利。在“优秀人才入境计划”下,获批准的申请者无须在来港定居前先获得本地僱主聘任。符合人才清单相关专业资格的申请者,可在“优秀人才入境计划”的“综合计分制”下获得额外分数。香港公布人才清单,多项优惠就等你来!香港优才计划申请条件评估网址(http://www.galaxy-immi.com/obscure/assessment/1.html?pla=sq&spreadword=heim)
回复 使用道具 举报
奈斯,感谢分享
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马