Java I/O专题

Java中的I/O模型
在JDK1.4之前,基于Java的所有socket都是使用阻塞I/O(BIO),JDK1.4提供了非阻塞I/O(NIO)功能,虽然称为NIO但实际上底层模型是I/O多路复用,JDK1.7提出了异步I/O(AIO)功能。

BIO/NIO/AIO区别概述:

  • BIO(Blocking I/O):同步阻塞I/O模式,数据的读写必须在一个线程内等待其完成。
  • NIO(Non-blocking/New I/O):同步非阻塞I/O模型。在Java1.4中引入了NIO框架,对应java.nio包,提供了Channel,Selector,Buffer等抽象。它支持面向缓冲,基于通道的I/O操作方法。NIO提供了与传统BIO中的SocketSeverSocket相对应的SocketChannelServerSocketChannel两种不同的套接字的通道实现,两种通道都支持阻塞和非阻塞I/O模型。阻塞模型同传统的I/O一样,比较简单但是性能和可靠性都不好;非阻塞模型正好与之相反。对于低负载、低并发的应用程序,可以使用同步阻塞I/O来提升开发速率和更好的维护性;对于高负载、高并发的(网络)应用,应使用NIO的非阻塞模型来开发。
  • AIO(Asynchronous I/O):AIO也就是NIO 2,于Java1.7中引入,它是异步非阻塞的IO模型。异步IO基于事件和回调机制实现,即应用操作之后会直接返回,不会阻塞在那里,当后台处理完成,操作系统会通知相应的线程进行后续的操作。

NIO虽然提供了非阻塞的方法,但是NIO的IO行为还是同步的,对于NIO来说,我们的业务线程是在IO操作准备好时,得到通知,接着就由这个线程自行进行I/O操作,IO操作本身是同步的。

待补充。。。

参考

来自Java Guide面试突击版,百度可得最新版本,这里有删减和修正。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值