> 本节介绍缓冲区的操作中,ByteBuffer的一些用法。
## ByteBuffer
- 分配直接内容
- 包装wrap数据的处理
### 缓冲区操作
使用allocateDirect()方法创建的直接缓冲区如何释放内存呢?有两种办法,一种是手动释放空间,另一种就是交给JVM进行处理。
java进程分配直接缓冲区,在java进程结束后也不会马上回收内存,而是会在某个时刻触发GC垃圾回收器进行内存的回收。
#### 压缩缓冲区
使用compact()可以进行缓冲区压缩。
![](https://gitee.com/cowboy2014/cloud2020-config/raw/master//pictures/20210502110712.png)
#### order(ByteOrder bo)方法
作用:设置字节的排列顺序。
不同的CPU在读取字节时的顺序是不一样的,有的CPU从高位开始读,而有的CPU从低位开始读,当这两种CPU传递数据时就要将字节排列的顺序进行统一。
> 字节顺序
> ByteOrder order()方法的作用:获取此缓冲区的字节顺序。新创建的字节缓冲区的顺序始终为BIG_ENDIAN。在读写多字节值以及为此字节缓冲区创建视图缓冲区时,使用该字节顺序。
> 1. `public static final ByteOrder BIG_ENDIAN`:表示BIG-ENDIAN字节顺序的常量。按照此顺序,多字节值的字节顺序是从最高有效位到最低有效位的。
> 2. `public static final ByteOrder LITTLE_ENDIAN`:表示LITTLE-ENDIAN字节顺序的常量。按照此顺序,多字节值的字节顺序是从最低有效位到最高有效位的
#### 比较缓冲区的内容
比较缓冲区的内容是否相同有两种方法:equals()和compareTo()。
- 前言
- 第一部分 计算机网络与操作系统
- 大量的 TIME_WAIT 状态 TCP 连接,对业务有什么影响?怎么处理?
- 性能占用
- 第二部分 Java基础
- 2-1 JVM
- JVM整体结构
- 方法区
- JVM的生命周期
- 堆对象结构
- 垃圾回收
- 调优案例
- 类加载机制
- 执行引擎
- 类文件结构
- 2-2 多线程
- 线程状态
- 锁与阻塞
- 悲观锁与乐观锁
- 阻塞队列
- ConcurrentHashMap
- 线程池
- 线程框架
- 彻底搞懂AQS
- 2-3 Spring框架基础
- Spring注解
- Spring IoC 和 AOP 的理解
- Spring工作原理
- 2-4 集合框架
- 死磕HashMap
- 第三部分 高级编程
- Socket与NIO
- 缓冲区
- Bybuffer
- BIO、NIO、AIO
- Netty的工作原理
- Netty高性能原因
- Rabbitmq
- mq消息可靠性是怎么保障的?
- 认证授权
- 第四部分 数据存储
- 第1章 mysql篇
- MySQL主从一致性
- Mysql的数据组织方式
- Mysql性能优化
- 数据库中的乐观锁与悲观锁
- 深度分页
- 从一条SQL语句看Mysql的工作流程
- 第2章 Redis
- Redis缓存
- redis key过期策略
- 数据持久化
- 基于Redis分布式锁的实现
- Redis高可用
- 第3章 Elasticsearch
- 全文查询为什么快
- battle with mysql
- 第五部分 数据结构与算法
- 常见算法题
- 基于数组实现的一个队列
- 第六部分 真实面试案例
- 初级开发面试材料
- 答案部分
- 现场编码
- 第七部分 面试官角度
- 第八部分 计算机基础
- 第九部分 微服务
- OpenFeign工作原理