《NIO与Socket编程技术指南》读书笔记

缓冲区

Buffer类的使用

传统的IO流常常把字节流中的数据放入byte或者char数组中,由于java对array数组操作的api较少,所以需要自己使用原始的处理方式(使用length属性等或者下标)处理数据,比较麻烦。这个问题可以使用Buffer缓冲区解决,Buffer类有多个子类:


《NIO与Socket编程技术指南》读书笔记_第1张图片
Buffer子类

使用这些子类表示缓冲区保存多种类型的数据,而不只是byte和char。

要注意的是,Buffer和它的子类都是抽象类,不能直接new出实例,需要将上面7种类型的数组包装(wrap)进缓冲区中,来构建不同数据结构的缓冲区。使用示例如下:

byte[] byteArray = new byte[]{1,2,3,4};
ByteBuffer byteBuffer = ByteBuffer.wrap(byteArray);

wrap方法实现如下:

public static ByteBuffer wrap(byte[] array,
                                    int offset, int length)
    {
        try {
            return new HeapByteBuffer(array, offset, length);
        } catch (IllegalArgumentException x) {
            throw new IndexOutOfBoundsException();
        }
    }

上面的HeapByteBuffer就是Buffer类的实现类,所以wrap的过程也是实例化对象的过程。
从ByteBuffer类内部:


《NIO与Socket编程技术指南》读书笔记_第2张图片
源码

wrap传入的数组最后保存在了ByteBuffer实例内部,所以Buffer类实际上还是对数组进行封装而已。

包装数据与获得容量

你可能感兴趣的:(《NIO与Socket编程技术指南》读书笔记)