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

相关推荐
浪扼飞舟几秒前
C#(多线程和同步异步)
java·开发语言
万行几秒前
机器人系统SLAM讲解
开发语言·python·决策树·机器学习·机器人
抬头望远方1 分钟前
【无人机】无人机群在三维环境中的碰撞和静态避障仿真(Matlab代码实现)
开发语言·支持向量机·matlab·无人机
matlab科研助手4 分钟前
【路径规划】基于遗传算法的农药无人机在多边形区域的路径规划研究附Matlab代码
开发语言·matlab·无人机
hanqunfeng6 分钟前
(三十三)Redisson 实战
java·spring boot·后端
2301_780669866 分钟前
字符集及其编码、解码操作、IO流分类
java·开发语言
计算机毕设指导610 分钟前
基于微信小程序的运动场馆服务系统【源码文末联系】
java·spring boot·微信小程序·小程序·tomcat·maven·intellij-idea
无名的小三轮14 分钟前
第三章 防火墙概述
开发语言·php
冰暮流星22 分钟前
javascript的switch语句介绍
java·前端·javascript
有梦想的攻城狮22 分钟前
Java中的Double类型的存在精度丢失详解
java·开发语言·bigdecimal·double