ByteBuffer详解

2024-08-28 01:04
文章标签 详解 bytebuffer

本文主要是介绍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());
    


这篇关于ByteBuffer详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1113285

相关文章

C语言中的浮点数存储详解

《C语言中的浮点数存储详解》:本文主要介绍C语言中的浮点数存储详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、首先明确一个概念2、接下来,讲解C语言中浮点型数存储的规则2.1、可以将上述公式分为两部分来看2.2、问:十进制小数0.5该如何存储?2.3 浮点

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

MySQL中COALESCE函数示例详解

《MySQL中COALESCE函数示例详解》COALESCE是一个功能强大且常用的SQL函数,主要用来处理NULL值和实现灵活的值选择策略,能够使查询逻辑更清晰、简洁,:本文主要介绍MySQL中C... 目录语法示例1. 替换 NULL 值2. 用于字段默认值3. 多列优先级4. 结合聚合函数注意事项总结C

Java实现数据库图片上传功能详解

《Java实现数据库图片上传功能详解》这篇文章主要为大家详细介绍了如何使用Java实现数据库图片上传功能,包含从数据库拿图片传递前端渲染,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、数据库搭建&nbsChina编程p; 3、后端实现将图片存储进数据库4、后端实现从数据库取出图片给前端5、前端拿到

Windows命令之tasklist命令用法详解(Windows查看进程)

《Windows命令之tasklist命令用法详解(Windows查看进程)》tasklist命令显示本地计算机或远程计算机上当前正在运行的进程列表,命令结合筛选器一起使用,可以按照我们的需求进行过滤... 目录命令帮助1、基本使用2、执行原理2.1、tasklist命令无法使用3、筛选器3.1、根据PID

MySql中的数据库连接池详解

《MySql中的数据库连接池详解》:本文主要介绍MySql中的数据库连接池方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql数据库连接池1、概念2、为什么会出现数据库连接池3、原理4、数据库连接池的提供商5、DataSource数据源6、DBCP7、C

Spring-AOP-ProceedingJoinPoint的使用详解

《Spring-AOP-ProceedingJoinPoint的使用详解》:本文主要介绍Spring-AOP-ProceedingJoinPoint的使用方式,具有很好的参考价值,希望对大家有所帮... 目录ProceedingJoinPoijsnt简介获取环绕通知方法的相关信息1.proceed()2.g

一文详解kafka开启kerberos认证的完整步骤

《一文详解kafka开启kerberos认证的完整步骤》这篇文章主要为大家详细介绍了kafka开启kerberos认证的完整步骤,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、kerberos安装部署二、准备机器三、Kerberos Server 安装1、配置krb5.con

Python使用DeepSeek进行联网搜索功能详解

《Python使用DeepSeek进行联网搜索功能详解》Python作为一种非常流行的编程语言,结合DeepSeek这一高性能的深度学习工具包,可以方便地处理各种深度学习任务,本文将介绍一下如何使用P... 目录一、环境准备与依赖安装二、DeepSeek简介三、联网搜索与数据集准备四、实践示例:图像分类1.

StarRocks数据库详解(什么是StarRocks)

《StarRocks数据库详解(什么是StarRocks)》StarRocks是一个高性能的全场景MPP数据库,支持多种数据导入导出方式,包括Spark、Flink、Hadoop等,它采用分布式架构,... 目录StarRocks介绍什么是StarRocks?StarRocks适合什么场景?StarRock