前面说到的NIO中Buffer一个用于保存特定基本数据类型的容器,其底层就是一个数组。
可以看到,基本类型除了boolean,其他的都对应一个Buffer的实现类。
对于抽象类Buffer,需要理解其以下几个属性:
private int mark = -1; //标志位,标记后能使调用reset方法能够恢复到标记时的位置
private int position = 0; //相当于一根指针,指向数组中当前正在操作的位置
private int limit; // 主要是读取缓冲区数组中的数组的时候,数据的范围
private int capacity; //缓冲区中的大小,一般分配之后就是固定的。
String str = "test";
//使用字节缓冲区,设置其大小为10
ByteBuffer buf = ByteBuffer.allocate(10);
//把数据存放到缓冲区中
buf.put(str.getBytes());
可以看到,test被保存在一个hb的数组中,其保存的是对应的ASCII码,此时postiton指向第四个元素,容量为10.
buf.flip();
在‘读’模式下,postiton归为0,从最开始读取,limit为4,只能读取四个。然后获取相应的数据:
byte[] dst = new byte[buf.limit()];
buf.get(dst);
System.out.println(new String(dst, 0, dst.length));
关于mark:
private static void testBuffer2() {
String str="this is a good day";
ByteBuffer buff2=ByteBuffer.allocate(1024);
buff2.put(str.getBytes());
System.out.println(buff2.position()); //标记第18个元素
buff2.mark(); //做标记
buff2.put("yes".getBytes()); //存放进buffer
System.out.println(buff2.position()); //指向第21个元素
buff2.reset(); //重置为之前的位置
System.out.println(buff2.position()); //又重新指向第18个元素位置
}
则有mark <= position <= limit <= capacity的结论