15.9 NIO 15.9.1 Java新IO概述
15.9 NIO 15.9.1 Java新IO概述
旧IO
旧IO阻塞
前面介绍BufferedReader
时提到它的一个特征—当BufferedReader
读取输入流中的数据时,如果没有读到有效数据,程序将在此处阻塞该线程的执行(使用InputStream
的read()
方法从流中读取数据时,如果数据源中没有数据,它也会阻塞该线程),也就是前面介绍的输入流、输出流都是阻塞式的输入、输出。
旧IO一次只能处理一个字节
不仅如此,传统的输入流、输出流都是通过字节的移动来处理的(即使不直接去处理字节流,但底层的实现还是依赖于字节处理),也就是说,面向流的输入输出系统一次只能处理一个字节,因此面向流的输入输出系统通常效率不高。
新IO
从JDK1.4
开始,Java
提供了一系列改进的输入输出处理的新功能,这些功能被统称为新IO
(New IO
,简称NIO
),新增了许多用于处理输入输出的类,这些类都被放在java.nio
包以及子包下,并且对原java.io
包中的很多类都以NIO
为基础进行了改写,新增了满足NIO
的功能。
15.9.1 Java新IO概述
新IO
和传统的IO
有相同的目的,都是用于进行输入输出,但新IO
使用了不同的方式来处理输入/输出。
内存映射文件方式
新IO
采用内存映射文件的方式来处理输入/输出,新IO
模拟了操作系统上的虚拟内存的概念:将文件或文件的一段区域映射到内存中,这样就可以像访问内存一样来访问文件了,通过这种方式来进行输入输出比传统的输入输出要快得多。
NIO相关包
Java
中与新IO
相关的包如下:
新IO 相关的包 |
描述 |
---|---|
java.nio 包 |
主要包含各种与Buffer 相关的类 |
java.nio.channels 包 |
主要包含与Channel 和Selector 相关的类。 |
java.nio.charset 包 |
主要包含与字符集相关的类 |
java.nio.channels.spi 包 |
主要包含与Channel 相关的服务提供者编程接口。 |
java.nio.charset.spi 包 |
包含与字符集相关的服务提供者编程接口。 |
Channel简介
Channel
(通道)和Buffer
(缓冲)是新IO
中的两个核心对象,Channel
是对传统的输入输出系统的模拟,在新IO
系统中所有的数据都需要通过通道传输;Channel
与传统的InputStream
、OutputStream
最大的区别在于它提供了一个map()
方法,通过该map()
方法可以直接将“一块数据”映射到内存中。
如果说传统的输入输出系统是面向流
的处理,则新IO
则是面向块
的处理。
Buffer简介
Buffer
可以被理解成一个容器,它的本质是一个数组,发送到Channel
中的所有对象都必须首先放到Buffer
中,而从Channel
中读取的数据也必须先放到Buffer
中。
此处的Buffer
有点类似于前面介绍的“竹筒”,但该Buffer
既可以像“竹筒”那样一次次去Channel
中取水,也允许使用Channel
直接将文件的某块数据映射成Buffer
Charset和Selector简介
除Channel
和Buffer
之外,
- 新
IO
还提供了用于将Unicode字符串映射成字节序列以及逆映射操作的Charset
类, - 也提供了用于支持非阻塞式输入输出的
Selector
类。