• 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面试突击版,百度可得最新版本,这里有删减和修正。

  • 相关阅读:
    继承在WCF中的问题和解决办法
    bootstrap插件学习-bootstrap.dropdown.js
    C#山寨版本拨号客户端
    关于Certificate、Provisioning Profile、App ID的介绍及其之间的关系
    [源码]Literacy 快速反射读写对象属性,字段
    Hadoop Streaming框架学习(一)
    AOP详解
    SESSION会话技术
    mongodb 备份、还原、导入、导出
    Qt 技巧: 解决未解析的SSL问题
  • 原文地址:https://www.cnblogs.com/wanghongze95/p/13842421.html
Copyright © 2020-2023  润新知