【NIO】ByteBuffer

ByteBuffer的使用

  1. 想ByteBuffer中写入数据,每次bytebuffer大小
  2. bytebuffer开启读模式(默认是写模式)
  3. 按照get(每次1字节)获取数据,知道bytebuffer中数据读取完毕
  4. 开启写模式clear/comact
  5. 再次读取文件信息(实际上每次读文件信息,文件也会有指针进行移动,下次再来读,按照移动后的指针位置开始进行读取)
java 复制代码
{
        try (FileChannel channel = new FileInputStream("aaa.txt").getChannel()) {
            // 缓冲区设置大小为10字节
            ByteBuffer byteBuffer =ByteBuffer.allocate(10);

            while (true) {
                int read = channel.read(byteBuffer);
                System.out.println("read:"+read);

                if (read <=0) {
                    break;
                }
                // 开启读模式
                byteBuffer.flip();
                // 当缓冲区还有剩余未读数据
                while (byteBuffer.hasRemaining()) {
                    // 获取1字节
                    System.out.println((char)byteBuffer.get());
                }

                // 切换成写模式
                byteBuffer.clear();

            }

        } catch (IOException e) {
        }
    }

NIO读写两种模式下,指针位置的变化,clear(写),filp(读),compact(写)

初始状态:ByteBuffer 初始化(容量 10)

  1. position
  2. capacity
  3. limit

plaintext

复制代码
┌───┬───┬───┬───┬───┬───┬───┬───┬───┬───┐
│   │   │   │   │   │   │   │   │   │   │
└───┴───┴───┴───┴───┴───┴───┴───┴───┴───┘
 ↑                   ↑
Position=0         Limit=10(=Capacity)
  • 刚创建 ByteBuffer,默认是写模式
  • Position=0(下一个写入位置),Limit=10(最大可写入位置)。

步骤 1:写入 4 字节数据(比如 "1234")

plaintext

复制代码
┌───┬───┬───┬───┬───┬───┬───┬───┬───┬───┐
│1  │2  │3  │4  │   │   │   │   │   │   │
└───┴───┴───┴───┴───┴───┴───┴───┴───┴───┘
         ↑           ↑
     Position=4    Limit=10
  • 写入 4 字节后,Position 从 0 移到 4(标记下一个写入位置);
  • Limit 仍 = 10(写模式下 Limit=Capacity)。

步骤 2:切换读模式(flip ())

plaintext

复制代码
┌───┬───┬───┬───┬───┬───┬───┬───┬───┬───┐
│1  │2  │3  │4  │   │   │   │   │   │   │
└───┴───┴───┴───┴───┴───┴───┴───┴───┴───┘
 ↑           ↑
Position=0  Limit=4
  • flip () 会把 Limit 设为当前 Position(4),Position 重置为 0;
  • 现在是读模式:可读取的范围是 Position=0 到 Limit=4。

步骤 3:读取 2 字节数据(比如 "12")

plaintext

复制代码
┌───┬───┬───┬───┬───┬───┬───┬───┬───┬───┐
│1  │2  │3  │4  │   │   │   │   │   │   │
└───┴───┴───┴───┴───┴───┴───┴───┴───┴───┘
     ↑       ↑
Position=2  Limit=4
  • 读取 2 字节后,Position 从 0 移到 2;
  • Limit 仍 = 4(读模式下 Limit = 已写入的总长度);
  • 此时还剩 2 字节未读("34")

步骤 4:切换写模式(compact ())

plaintext

复制代码
┌───┬───┬───┬───┬───┬───┬───┬───┬───┬───┐
│3  │4  │   │   │   │   │   │   │   │   │
└───┴───┴───┴───┴───┴───┴───┴───┴───┴───┘
     ↑                   ↑
Position=2             Limit=10
  • compact () 会把未读的 2 字节("34")移动到缓冲区开头
  • 然后 Position 设为 "未读字节的长度"(2),Limit 重置为 Capacity(10);
  • 现在是写模式:新数据会从 Position=2 开始写入(不会覆盖未读的 "34")。

步骤 5:再写入 3 字节数据(比如 "567")

plaintext

复制代码
┌───┬───┬───┬───┬───┬───┬───┬───┬───┬───┐
│3  │4  │5  │6  │7  │   │   │   │   │   │
└───┴───┴───┴───┴───┴───┴───┴───┴───┴───┘
         ↑               ↑
     Position=5         Limit=10
  • 从 Position=2 开始写入 3 字节,Position 移到 5;
  • 此时缓冲区数据是 "34567",后续可继续写入到 Position=10。
相关推荐
chilavert3182 小时前
技术演进中的开发沉思-278 AJax :Rich Text(上)
前端·javascript·ajax
Jay丶2 小时前
*** 都不用tailwind!!!哎嘛 真香😘😘😘
前端·javascript·react.js
Tomorrow'sThinker2 小时前
篮球裁判犯规识别系统(四) foul_fn函数 上
java·前端·javascript
瞎子拍照2 小时前
echarts自定义主题样式与组件配置、数据滚动条和数据自动轮播功能
前端·javascript·echarts
不被神过问的人2 小时前
高德API索引点聚合实现地图看房
前端
狂炫冰美式2 小时前
Meta 收购 Manus:当巨头搭台时,你要做那个递钥匙的人
前端·人工智能·后端
与光_同尘3 小时前
一个隐蔽的 DOM 陷阱:id="nodeName" 引发的血案
前端
雲墨款哥3 小时前
React小demo,评论列表
前端·react.js