1.NIO的介绍
1.1由来
BufferedReader和InputStream从流中读取数据时,没有读到有效的数据,程序就会在此处阻塞该线程的执行。传统的输入流、输出流都是通过字节的移动来处理(即使不直接去处理字节流,但是底层的实现还是依赖于字节的处理),也就是说,面向流的输入输出系统都是一次只能处理一个字节,都会产生阻塞,因此面向流的输入输出系统通常效率不高。
jdk1.4开始,java提供了一系列改进的输入输出处理的新功能,这些功能被统称为新IO,新增了许多用于处理输入和输出的类,这些类都被放在了java.nio包的以及子包下,并且对源java.io包中的许多类都以NIO为基础进行改写,新增了满足NIO的功能。
新IO和传统的IO的主要区别在处理输入和输出的方式上,新IO将文件或文件的一段区域映射到内存中,这样就可以像访问内存一样来访问文件了(这种方式模拟了操作系统上的虚拟内存的概念),这样处理的速度就会提升很多。
1.2新IO的核心对象
Channel(通道):在新IO中所有的数据都需要通过通道传输,Channnel于传统的Inputstream、Outputstream最大的区别在于它提供了一个map()方法,通过该方法将“一块数据”映射到内存中,如果说传统的输入输出时面向流的处理,新IO则是面向块的处理。
Buffer(缓冲):可以被理解成一个容器,其本质是一个数组,发送数据到channel或者是从channel中读取数据都要先让如buffer中。
除了Channel和Buffer之外,新IO还提供了用于将