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逻辑上组合到一起,避免内存复制。

相关推荐
Henry Zhu1237 分钟前
Qt Model/View架构详解(五):综合实战项目
开发语言·qt·架构
孞㐑¥9 分钟前
算法—滑动窗口
开发语言·c++·经验分享·笔记·算法
AI-小柒18 分钟前
从零入门大语言模型(LLM):系统学习路线与实践指南
大数据·开发语言·人工智能·学习·信息可视化·语言模型·自然语言处理
invicinble21 分钟前
关于对后端开发工程师,在项目层面的基本需求与进阶方向
java
hhy_smile22 分钟前
Python environment and installation
开发语言·python
懒鸟一枚24 分钟前
Java17新特性详解
java
戌中横26 分钟前
JavaScript 对象
java·开发语言·javascript
crossaspeed26 分钟前
面向对象的三大特征和反射(八股)
java·开发语言
连山齐名32 分钟前
程序员棋谱之一——单例模式
开发语言·单例模式
zfj32136 分钟前
java synchronized关键字用法和底层原理
java·开发语言·轻量级锁·重量级锁·偏向锁·线程同步