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

相关推荐
S***q1926 分钟前
Rust在系统工具中的内存安全给代码上了三道保险锁。但正是这种“编译期的严苛”,换来了运行时的安心。比如这段代码:
开发语言·后端·rust
M***Z2109 分钟前
SQL 建表语句详解
java·数据库·sql
v***7949 分钟前
Spring Boot 热部署
java·spring boot·后端
执笔论英雄10 分钟前
【RL】python协程
java·网络·人工智能·python·设计模式
打点计时器13 分钟前
matlab 解决wfdb工具使用本地数据集报错
开发语言·matlab
zmzb010318 分钟前
C++课后习题训练记录Day38
开发语言·c++
galaxyffang21 分钟前
认证、会话管理、授权的区别
java
未名编程25 分钟前
Windows 下如何部署 Nacos 并导入配置文件
java·windows
夏霞29 分钟前
c# 使用vs code 创建.net8.0以及.net6.0 webApi项目的教程
开发语言·c#·.net
boonya30 分钟前
Java中Plugin设计模式的规范应用
java·spring·设计模式·插件模式