Netty 组件介绍 - ByteBuf

直接内存&堆内存

java 复制代码
   ByteBuf buffer = ByteBufAllocator.DEFAULT.heapBuffer(10);

   ByteBuf byteBuf = ByteBufAllocator.DEFAULT.directBuffer(10);

组成

ByteBuf维护了两个不同的索引,一个用于读取,一个用于写入。

写入

内存回收

  • 堆内存使用的是JVM内存,等待GC即可。
  • 直接内存,建议手动回收内存

Netty采用引用计数法来控制回收内存。谁是最终使用者,谁来释放ButeBuf.

  • 每个ByteBuf对象的初始计数为1
  • 调用relase方法计数减1,如果计数为0,ByteBuf被回收
  • 调用retain方法啊计数加一,表示调用者没用完之前,其他hander即使调用了release也不会造成回收。

slice

对原始的ByteBuf进行切片成多个ButeBuf,切片后的ButeBuf拥有独立的读写指针。切片后对最大容量做了限制。

composite

将ByteBuf逻辑上组合到一起,避免内存复制。

相关推荐
程序员小假9 分钟前
MySQL 与 Redis 如何保证双写一致性?
java·后端
Arlene12 分钟前
JVM Java虚拟机
java·开发语言·jvm
千码君201615 分钟前
Go语言:关于导包的两个重要说明
开发语言·后端·golang·package·导包
oak隔壁找我19 分钟前
Java 高级特性
java·后端
9527出列22 分钟前
Netty源码分析--客户端连接接入流程解析
网络协议·netty
骈拇23 分钟前
重写、重载、访问者模式
java
88号技师29 分钟前
2025年8月SCI-汉尼拔·巴卡优化算法Hannibal Barca optimizer-附Matlab免费代码
开发语言·人工智能·算法·数学建模·matlab·优化算法
_w_z_j_32 分钟前
C++----变量存储空间
开发语言·c++
花菜会噎住41 分钟前
Vue3 路由配置和使用与讲解(超级详细)
开发语言·javascript·ecmascript·路由·router
老K的Java兵器库41 分钟前
对象创建源码追踪:从 new 指令到 JVM 内部实现
java·jvm