java.io
java.nio
java.io中最为核心的一个概念是流(Stream),面向流的编程。java中,一个流要么是输入流,要目是输出流,不可能同时即是输入流又是输出流。
java.nio中有3个核心概念:Selector(选择器),Channel(通道)与Buffer(缓冲区)。在java.nio中,我们是面向块(block)或是缓冲区(buffer)编程的。Buffer本身就是一块内存,底层实现上,它实际上是个数组。数据的读、写都是通过buffer来实现的。
buffer.flip(); //进行读写切换
除了数组之外,Buffer还提供了对于数据的结构化访问方式,并且可以追踪到系统的读写过程。
Java中8中原生数据类型都有各自对应的Buffer类型,例如IntBuffer,LongBuffer,ByteBuffer以及CharBuffer等。
Channel指的是可以向其写入数据或是从中读取数据的对象,它类似于java.io中的stream。
所有数据的读写都是通过Buffer来进行的,永远不会出现直接向Channel写入数据的情况,或是直接从Channel读取数据的情况。
与Stream不同的是,Channel是双向的,一个流只可能是InputStream或是OutPutStream,Channel打开后则可以进行读取、写入或者读写。
由于Channel是双向的,因此它能更好地反映出底层操作系统的真实情况;在Linux系统中,底层操作系统的通道就是双向的。
javaNioComponent.png
网友评论