67. netty系列之:JVM中的Reference count原来netty中也有
简介
为什么世界上有这么多JAVA的程序员呢?其中一个很重要的原因就是JAVA相对于C++而言,不需要考虑对象的释放,一切都是由垃圾回收器来完成的。在崇尚简单的现代编程世界中,会C++的高手越来越少,会JAVA的程序员越来越多。
JVM的垃圾回收器中一个很重要的概念就是Reference count,也就是对象的引用计数,用来控制对象是否还被引用,是否可以被垃圾回收。
netty也是运行在JVM中的,所以JVM中的对象引用计数也适用于netty中的对象。这里我们说的对象引用指的是netty中特定的某些对象,通过对象的引用计数来判断这些对象是否还被使用,如果不再被使用的话就可以把它们(或它们的共享资源)返回到对象池(或对象分配器)。
这就叫做netty的对象引用计数技术,其中一个最关键的对象就是ByteBuf。
ByteBuf和ReferenceCounted
netty中的对象引用计数是从4.X版本开始的,ByteBuf是其中最终要的一个应用,它利用引用计数来提高分配和释放性能.
先来看一下ByteBuf的定义:
public abstract class ByteBuf implements ReferenceCounted, Comparable<ByteBuf>
可以看到ByteBuf是一个抽象类,它实现了ReferenceCounted的接口。
ReferenceCounted就是netty中对象引用的基础,它定义了下面几个非常重要的方法,如下所示:
int refCnt();
ReferenceCounted retain();
ReferenceCounted retain(int increment);
boolean release();
boolean release(int decrement);
其中refCnt返回的是当前引用个数,retain用来增加引用,而release用来释放引用。
ByteBuf的基本使用
刚分配情况下ByteBuf的引用个数是1:
ByteBuf buf = ctx.alloc().directBuffer();
assert buf.refCnt() == 1;
当调用他的release方法之后,refCnt就变成了0:
boolean destroyed = buf.release();
assert destroyed;
assert buf.refCnt() == 0;
当调用它的retain方法,refCnt就会加一:
ByteBuf buf = ctx.alloc().directBuffer();
assert buf.refCnt() == 1;
buf.retain();
assert buf.refCnt() == 2;