当前位置: 首页 > news >正文

ByteBuffer详解

文章目录

  • 1. ByteBuffer是抽象类,他的主要实现类为
  • 2. 获取方式
  • 3. 核心结构
  • 4. 核心API
  • 5. 字符串操作

在这里插入图片描述


1. ByteBuffer是抽象类,他的主要实现类为

  1. HeapByteBuffer 堆ByteBuffer JVM内的堆内存 —> 读写操作 效率低 会受到GC影响
  2. MappedByteBuffer(DirectByteBuffer) OS内存 —> 读写操作 效率高 不会受到GC影响 。 DirectByteBuffer使用过程中,若不主动析构,会造成内存的泄露!

2. 获取方式

  1. ByteBuffer.allocate(10); //一旦分配空间,不可以动态调整
  2. encode()

3. 核心结构

  1. Capacity
    • 定义:缓冲区能够容纳的最大字节数。
    • 性质:这个值在缓冲区创建时就被确定,并且在缓冲区的生命周期内是固定不变的。
    • 作用:决定了缓冲区可以存储多少数据。
  2. Position
    • 定义:缓冲区当前操作的位置,表示下一个可以读或写的字节的位置
    • 性质:这个值在缓冲区的操作过程中会变化。当你读取或写入数据时,Position 会相应地移动。
    • 作用:用于跟踪缓冲区当前的数据操作位置。
  3. Limit
    • 定义:缓冲区的限制,表示缓冲区的有效数据区域的结束位置
    • 性质:在缓冲区的读写过程中,Limit 是一个限制值,读取或写入操作不能超过这个值。Limit 的初始值通常等于缓冲区的 Capacity
    • 作用:用来限制对缓冲区的访问范围,在读取或写入数据时,Limit 定义了操作的结束位置。

所谓的读写模式,本质上就是这几个状态的变化。主要有Position和Limit联合决定了Buffer的读写数据区域。这三个属性的协调使用,使得 ByteBuffer 可以有效地管理数据的读写操作。

假设你有一个容量为 10 的缓冲区,初始状态下:

  • Capacity = 10
  • Position = 0
  • Limit = 10

你往缓冲区写入 5 个字节:

  • Position 更新为 5(因为你写了 5 个字节)
  • Limit 依然是 10

然后你可以调用 flip() 方法,将缓冲区从写模式切换到读模式,这会使:

  • Limit 更新为当前的 Position(即 5)
  • Position 重置为 0

在读模式下,你只能读取到 Limit 位置的数据,不能超过这个位置。

在这里插入图片描述


4. 核心API

往 buffer 中写入数据 [前提是写模式 创建一个bytebuffer ,clear(), compact()]

1. channel的read方法channel.read(buffer)2. buffer的put方法buffer.put(byte)    buffer.put((byte)'a')..buffer.put(byte[])

从buffer中读出数据

1. channel的write方法2. buffer的get方法 //每调用一次get方法会影响,position的位置。3. rewind方法(手风琴),可以将postion重置成0 ,用于复读数据。4. mark&reset方法,通过mark方法进行标记(position),通过reset方法跳回标记,从新执行.5. get(i) 方法,获取特定position上的数据,但是不会对position的位置产生影响。

5. 字符串操作

  • 字符串存储到Buffer中

    ByteBuffer buffer = ByteBuffer.allocate(10);
    buffer.put("Hello,Nrtty!".getBytes());buffer.flip();
    while (buffer.hasRemaining()) {System.out.println("buffer.get() = " + (char)buffer.get());
    }
    
    buffer.clear();ByteBuffer buffer = Charset.forName("UTF-8").encode("Hello,Nrtty!");
    while (buffer.hasRemaining()) {System.out.println("buffer.get() = " + (char) buffer.get());
    }
    1、encode方法自动 把字符串按照字符集编码后,存储在ByteBuffer.
    2、自动把ByteBuffer设置成读模式,且不能手工调用flip方法。
    
    buffer.clear();
    ByteBuffer buffer = StandardCharsets.UTF_8.encode("Hello,Nrtty!");while (buffer.hasRemaining()) {System.out.println("buffer.get() = " + (char) buffer.get());
    }
    
    buffer.clear();
    1、encode方法自动 把字符串按照字符集编码后,存储在ByteBuffer.
    2、自动把ByteBuffer设置成读模式,且不能手工调用flip方法。ByteBuffer buffer = ByteBuffer.wrap("Hello,Nrtty!".getBytes());
    while (buffer.hasRemaining()) {System.out.println("buffer.get() = " + (char) buffer.get());
    }
    
  • Buffer中的数据转换成字符串

    ByteBuffer buffer = ByteBuffer.allocate(10);
    buffer.put("长安初雪".getBytes());buffer.flip();
    CharBuffer charBuffer = StandardCharsets.UTF_8.decode(buffer);
    System.out.println("charBuffer.toString() = " + charBuffer.toString());
    



http://www.mrgr.cn/news/11798.html

相关文章:

  • 安装docker+docker远程连接
  • Edge-TTS:微软推出的,免费、开源、支持多种中文语音语色的AI工具[Python代码]
  • vue事件监听
  • “互联网+”在职业教育中的应用
  • 【运维】docker搭建portainer
  • vue中的监听器(watch,watchEffect)和计算属性(computed)
  • 《C++魔法:构造函数与析构函数的神秘力量》
  • Vue3:命名路由
  • Spring cloud alibaba(二)RibbonLoadBalance
  • OpenCV几何图像变换(4)亚像素图像截取函数getRectSubPix()的使用
  • SQL进阶技巧:近距离有效的缺失值填充问题【last_value实现版】
  • 什么是红黑树-面试中常问的数据结构
  • ARM32开发——(八)中断
  • 【计算阶乘求和】计算1!+3!+5!+...+n!/(n+1)!
  • SSRF以及CSRF
  • Datawhale X 李宏毅苹果书 AI夏令营|机器学习基础之案例学习
  • Java | Leetcode Java题解之第375题猜数字大小II
  • 计算机毕业设计选题推荐-高中素质评价档案系统-Java/Python项目实战
  • 数据结构;顺序表;链式表
  • 天玑9400顶级图形技术曝光,GPU新技术让光追画质超一个档次