ByteBuffer的数据结构
ByteBuffer 是属于java的nio部分,在编程的高端操作中经常看到它的身影,如果网络编程,比如安卓中的硬编解码(MediaCodeC)中…
组成部分
- byte[] bytes: 用来存储数据
- int capacity: 用来表示bytes的容量,那么可以想像capacity就等于bytes.size(),此值在初始化bytes后,是不可变的。
- int limit: 用来表示bytes实际装了多少数据,可以容易想像得到limit <= capacity,此值是可灵活变动的
- int position: 用来表示在哪个位置开始往bytes写数据或是读数据,此值是可灵活变动的
如何创建
ByteBuffer.allocate(int cap)即可创建一个指定容器大小的ByteBuffer。
如何理解
position 是一个非常重要的地方,数据的来源是从position开始。position 变量跟踪已经写了多少数据。更准确地说,它指定了下一个字节将放到数组的哪一个元素中。 比如 put/get 之后,position会向后移动对应的值。
当然position也是可以手动控制的:
byteBuffer.position(0); //设置position到0位置,这样读数据时就从这个位置开始读
示例代码:
public class Test5 {
public static void main(String[] args) {
ByteBuffer byteBuffer = ByteBuffer.allocate(20);
System.out.println("创建一个容量为20的byteBuffer");
System.out.println("输出原始byteBuffer");
System.out.println(byteBuffer);
System.out.println(Arrays.toString(byteBuffer.array()));
byte[] bytes = new byte[10];
for (int i = 0; i< bytes.length; i++){
bytes[i] = (byte) i;
}
byteBuffer.put(bytes);
System.out.println("输出put(bytes)后的byteBuffer");
System.out.println(byteBuffer);
System.out.println(Arrays.toString(byteBuffer.array()));
byte[] byte2 = new byte[10];
byteBuffer.get(byte2);
System.out.println("输出get(byte2)后的byteBuffer");
System.out.println(byteBuffer);
System.out.println(Arrays.toString(byteBuffer.array()));
System.out.println(Arrays.toString(byte2));
System.out.println("移动position");
byteBuffer.position(0);
byteBuffer.get(byte2);
System.out.println("再次输出get(byte2)后的byteBuffer");
System.out.println(byteBuffer);
System.out.println(Arrays.toString(byteBuffer.array()));
System.out.println(Arrays.toString(byte2));
}
}
运行结果:
创建一个容量为20的byteBuffer
输出原始byteBuffer
java.nio.HeapByteBuffer[pos=0 lim=20 cap=20]
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
输出put(bytes)后的byteBuffer
java.nio.HeapByteBuffer[pos=10 lim=20 cap=20]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
输出get(byte2)后的byteBuffer
java.nio.HeapByteBuffer[pos=20 lim=20 cap=20]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
移动position
再次输出get(byte2)后的byteBuffer
java.nio.HeapByteBuffer[pos=10 lim=20 cap=20]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]