【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。
相关推荐
作业逆流成河6 分钟前
别再一次性重构枚举了:如何把一个真实后台项目的状态字典,渐进式迁移到enum-plus?
前端·javascript·开源
暗不需求7 分钟前
React 性能优化秘籍:深入理解 `useMemo` 与 `useCallback`
前端·react.js·面试
专注VB编程开发20年13 分钟前
我制作excel工作簿的选项卡,发给deep seek, 昨天修改了一天
前端·vue.js·excel
light blue bird19 分钟前
工序路径主子表单工序组装图表组件
前端·数据库·信息可视化·.net·web端·razor page
linlinlove230 分钟前
前端uniapp、后端thinkphp股票系统开发功能展示、代码披露、HQChart
前端·uni-app·echarts·thinkphp·hqchart·配资·deepseek选股票
万少34 分钟前
Claude Code 任务结束会自己喊你:一个 Stop Hook 搞定提示音
前端·后端·代码规范
ZC跨境爬虫42 分钟前
跟着 MDN 学CSS day_30:(玩转列表样式,从基础到进阶)
前端·css·html·tensorflow·媒体
ct9781 小时前
TypeScript 中的泛型
前端·javascript·typescript
IT_陈寒1 小时前
React hooks闭包陷阱把我坑惨了,原来这才是正确用法
前端·人工智能·后端
nnsix1 小时前
MVC、MVP、MVVM 架构 笔记
java·开发语言·前端