ByteBuf内存分配和释放由具体实现负责,抽象类型只定义的内存分配和释放的时机。
内存分配分两个阶段: 第一阶段,初始化时分配内存。第二阶段: 内存不够用时分配新的内存。ByteBuf抽象层没有定义第一阶段的行为,但定义了第二阶段的方法:
public abstract ByteBuf capacity(int newCapacity)
这个方法负责分配一个长度为newCapacity的新内存。
内存释放的抽象实现在AbstractReferenceCountedByteBuf中实现,这个类实现引用计数,当调用release方法把引用计数变成0时,会调用
protected abstract void deallocate()
执行真正的内存释放操作。
内存相关的属性
ByteBuf定义了两个内存相关的属性:
capacity: 当前的当前的容量,也就是当前使用的内存大小。使用capacity()方法获得。
maxCapacity: 最大容量,也就是可以使用的最大内存大小。使用newCapacity()方法获得。
内存分配时机
AbstractByteBuf定义了内存分配的时机。当writeXX方法被调用的时候,如果如果发现可写空间不足,就调用capacity分配新的内存。下面以writeInt为例详细分析这个过程。
1 @Override
2 public ByteBuf writeInt(int value) {
3 ensureWritable0(4);
4 _setInt(writerIndex, value);
5 writerIndex += 4;
6 return this;
7 }
8
9
10 final void ensureWritable0(int minWritableBytes) {
11 ensureAccessible();
12 if (minWritableBytes <= writableBytes()) {
13 return;
14 }
15
16 if (minWritableBytes > maxCapacity - writerIndex) {
17 throw new IndexOutOfBoundsException(String.format(
18 "writerIndex(%d) + minWritableBytes(%d) exceeds maxCapacity(%d): %s",
19 writerIndex, minWritableBytes, maxCapacity, this));
20 }
21
22 // Normalize the current capacity to the power of 2.
23 int newCapacity = calculateNewCapacity(writerIndex + minWritableBytes);
24
25 // Adjust to the new capacity.
26 capacity(newCapacity);
27 }
28