【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。
相关推荐
小李子呢02113 小时前
前端八股CSS(2)---动画的实现方式
前端·javascript
GreenTea4 小时前
从 Claw-Code 看 AI 驱动的大型项目开发:2 人 + 10 个自治 Agent 如何产出 48K 行 Rust 代码
前端·人工智能·后端
渣渣xiong5 小时前
从零开始:前端转型AI agent直到就业第五天-第十一天
前端·人工智能
布局呆星5 小时前
Vue3 | 组件通信学习小结
前端·vue.js
C澒5 小时前
IntelliPro 企业级产研协作平台:前端智能生产模块设计与落地
前端·ai编程
OpenTiny社区6 小时前
重磅预告|OpenTiny 亮相 QCon 北京,共话生成式 UI 最新技术思考
前端·开源·ai编程
前端老实人灬6 小时前
web前端面试题
前端
Moment7 小时前
AI 全栈指南:NestJs 中的 Service Provider 和 Module
前端·后端·面试
IT_陈寒7 小时前
为什么我的JavaScript异步回调总是乱序执行?
前端·人工智能·后端