NIO
从JDK1.4开始,java提供了一系列改进输入/输出的新特性,统称为NIO,全称n为new I/O,是同步非阻塞的,所以也有人称为non-blocking I/O。NIO的相关类都放在java.nio包或其子包下,并对原先java.io包中许多类进行了改写。
NIO的三大核心
缓冲区(Buffer)
NIO是面向缓冲区, 或者说是面向块编程的。在NIO的IO传输中,数据会先读入到缓冲区,当需要时再从缓冲区写出,这样减少了直接读写磁盘的次数,提高了IO传输的效率。
缓冲区(buffer)本质上是一个可以读写数据的内存块,即在内存空间中预留了一定的存储空间,这些存储空间用来缓冲输入和输出的数据,这部分预留的存储空间就叫缓冲区。
在NIO程序中,通道channel虽然负责数据的传输,但是输入和输出的数据都必须经过缓冲区buffer。
在java中,缓冲区的相关类都在java.nio包下,其最顶层的类是 Buffer,它是一个抽象类。
Buffer类的4个重要属性:
-
mark:标记
-
position:位置,下一个要被读或写的元素的索引,每次读写缓冲区都会改变该值,为下次读写做准备
-
limit:表示缓冲区的终点,不能对缓冲区中超过极限的位置进行读写操作,且极限是可修改的
-
capacity:容量,即缓冲区的最多可容纳的数据量,该值在创建缓冲区时被设立,且不可修改
Buffer类常用方法:
Buffer的常用子类(它们之间最大区别在于底层实现数组的数据类型):
-
ByteBuffer:存储字节数据到缓冲区
-
CharBuffer:存储字符数据到缓冲区
-
IntBuffer:存储整型数据到缓冲区
-
ShortBuffer:存储短整型数据到缓冲区
-
LongBuffer:存储长整型数据到缓冲区
-
FloatBuffer:存储浮点型数据到缓冲区
-
DoubleBuffer:存储双精度浮点型数据到缓冲区
ByteBuffer
在Buffer的所有子类中,最常用的还是ByteBuffer,它的常用方法: