Java IO流,详细介绍,及用法
三种IO共存:BIO、NIO、AIO Java BIO BIO 全称Block-IO 是一种同步且阻塞的通信模式。是一个比较传统的通信方式,模式简单,使用方便。但并发处理能力低,通信耗时,依赖网速。 Java NIO NIO 全称Non-Block IO 是Java SE 1.4版以后,针对网络传输效能优化的新功能。是一种非阻塞同步的通信模式。 NIO 与原来的I/O有同样的作用和目的,他们之间最重要的区别是数据打包和传输方式。原来的I/O 以流的方式处理数据,而NIO 以块的方式处理数据。 面向流的I/O系统一次一个字节的处理数据。一个输入流产生一个字节的数据,一个输出流的消费一个字节的数据。 面向快的I/O系统以快的形式处理数据。每一个操作都在一步中产生或者消费一个数据块。按快处理数据比较流式的的字节处理数据速度要快得多。但是面向块的I/O 缺少一些面向流的I/O所具有的优雅性和简单性。 Java AIO AIO 全称Asynchronous IO 是异步非阻塞的IO。是一种非阻塞异步的通信模式。 在NIO的基础上引入了新的异步通道的概念,并提供了异步文件通道和异步套接字通道的实现。 三种IO的区别: BIO:同步阻塞I/O模式。 NIO:同步非阻塞模式。 AIO:异步非阻塞I/O模式。 同步阻塞模式:在这种模式下,我们的工作模式是先来到厨房,开始烧水