个人学习

Java NIO(2) - 缓冲区(Buffer)

2020-05-12  本文已影响0人  21号新秀_邓肯

3. 缓冲区(Buffer)和通道(Channel)

Java NIO系统的核心在于:通道(Channel)和缓冲区(Buffer)。通道表示打开到 IO 设备(例如:文件、套接字)的连接。若需要使用 NIO 系统,需要获取用于连接 IO 设备的通道以及用于容纳数据的缓冲区。然后操作缓冲区,对数据进行处理

<font color='red'>简而言之,Channel负责传输,Buffer负责存储</font>

3.1 缓冲区(Buffer)的简介

3.2 缓冲区的基本属性

image.png

3.3 Buffer 的常用方法

image.png

3.4 缓冲区的数据操作

Buffer 所有子类提供了两个用于数据操作的方法:get() 与 put() 方法

/**
 * Date: 2020/5/12
 * Time: 14:53
 * Content:
 *
 * 一.缓冲区(Buffer):在java NIO 中负责数据的存取.缓冲区就是数组.用于存储不同数据类型的数据
 *
 * 根据数据类型不同(boolean除外), 提供了相应类型的缓冲区
 * ByteBuffer
 * CharBuffer
 * ShortBuffer
 * IntBuffer
 * LongBuffer
 * FloatBuffer
 * DoubleBuffer
 *
 * 上述缓冲区的管理方式几乎一致, 通过allocate() 获取缓冲区
 *
 *
 * 二. 缓冲区存取数据的两个核心方法:
 * put() : 存入数据到缓冲区中
 * get() : 获取缓冲区中的数量
 *
 * 四. 缓冲区中的四个核心属性:
 * capacity : 容量, 表示缓冲区中糗大存储数据的容量.一旦声明不能改变
 * limit    : 界限, 表示缓冲区中可以操作数据的大小.(limit 后数据不能进行读写)
 * position : 位置, 表示缓冲区中正在操作数据的位置
 *
 * mark     : 标记, 表示记录当前 position 的位置, 可以通过 reset() 恢复到 mark 的位置
 *
 *
 * position <= limit <= capacty
 */
public class TestBuffer {

    @Test
    public void test01() {
        String str = "wangpeng";
        //1.分配一个指定大小的缓冲区
        ByteBuffer buf = ByteBuffer.allocate(1024);

        System.out.println("---------------allocate---------");
        System.out.println(buf.position());
        System.out.println(buf.limit());
        System.out.println(buf.capacity());

        //2. 利用put() 存入数据到缓冲区中
        buf.put(str.getBytes());

        System.out.println("---------------put---------");
        System.out.println(buf.position());
        System.out.println(buf.limit());
        System.out.println(buf.capacity());

        //3.切换读取数据模式
        buf.flip();

        System.out.println("---------------flip---------");
        System.out.println(buf.position());
        System.out.println(buf.limit());
        System.out.println(buf.capacity());

        //4. 利用 get() 读取缓冲区中的数据
        byte[] dst = new byte[buf.limit()];
        buf.get(dst);
        System.out.println(new String(dst, 0, dst.length));

        System.out.println("---------------get---------");
        System.out.println(buf.position());
        System.out.println(buf.limit());
        System.out.println(buf.capacity());

        //5, rewind() : 可重复读
        buf.rewind();

        System.out.println("---------------rewind---------");
        System.out.println(buf.position());
        System.out.println(buf.limit());
        System.out.println(buf.capacity());

        //6. clear() : 清空缓冲区, 但是缓冲区中的数据依然在,处于"遗忘"状态
        buf.clear();

        System.out.println("---------------clear---------");
        System.out.println(buf.position());
        System.out.println(buf.limit());
        System.out.println(buf.capacity());

        System.out.println((char) buf.get());
    }

    @Test
    public void test02() {
        String str = "zhaopeng";

        ByteBuffer buf = ByteBuffer.allocate(1024);
        buf.put(str.getBytes());
        buf.flip();

        byte[] dst = new byte[buf.limit()];
        buf.get(dst, 0, 2);
        System.out.println(new String(dst, 0, 2));
        System.out.println(buf.position());

        //mark() : 标记
        buf.mark();

        buf.get(dst, 2, 2);
        System.out.println(new String(dst, 2, 2));
        System.out.println(buf.position());

        //reset() : 恢复到 mark 的位置
        buf.reset();
        System.out.println(buf.position());

        //判断缓冲区中是否还有剩余数据
        if (buf.hasRemaining()) {
            //获取缓冲区中可以操作的数量
            System.out.println(buf.remaining());
        }
    }
}
上一篇 下一篇

猜你喜欢

热点阅读