Netty源码分析第5章(ByteBuf)---->第3节: 缓冲区分配器

 

Netty源码分析第五章: ByteBufhtml

 

第三节: 缓冲区分配器api

 

缓冲区分配器, 顾明思议就是分配缓冲区的工具, netty, 缓冲区分配器的顶级抽象是接口ByteBufAllocator, 里面定义了有关缓冲区分配的相关api工具

抽象类AbstractByteBufAllocator实现了ByteBufAllocator接口, 而且实现了其大部分功能源码分析

AbstractByteBuf同样, AbstractByteBufAllocator也实现了缓冲区分配的骨架逻辑, 剩余的交给其子类this

 

以其中的分配ByteBuf的方法为例, 对其作简单的介绍:spa

public ByteBuf buffer() { if (directByDefault) { return directBuffer(); } return heapBuffer(); }

这里if (directByDefault)会判断默认建立的ByteBuf是否是一个基于直接内存的ByteBuf, 也就是direct类型的ByteBuf, 若是是, 则经过directBuffer()方法返回direct类型的ByteBuf, 不然, 会经过heapBuffer()返回heap类型的ByteBufnetty

 

跟到directBuffer()方法中:code

public ByteBuf directBuffer() { return directBuffer(DEFAULT_INITIAL_CAPACITY, Integer.MAX_VALUE); }

这里又调用了一个重载directBuffer方法, 其中DEFAULT_INITIAL_CAPACITY表明分配的默认容量, Integer.MAX_VALUE表示分配的ByteBuf可扩容的最大容量, 也就是Integer类型的最大值, 咱们再跟进去:orm

public ByteBuf directBuffer(int initialCapacity, int maxCapacity) { if (initialCapacity == 0 && maxCapacity == 0) { return emptyBuf; } validate(initialCapacity, maxCapacity); return newDirectBuffer(initialCapacity, maxCapacity); }

这里判断若是初始容量和最大容量都为0的话, 则返回一个emptyBuf的成员变量, emptyBuf表明一个空的ByteBufhtm

而后经过validate方法进行参数验证

最后newDirectBuffer建立一个Direct类型的ByteBuf, 并将初始容量和最大容量传入

AbstractByteBufAllocator, newDirectBuffer是一个抽象方法, 由其子类实现

 

protected abstract ByteBuf newDirectBuffer(int initialCapacity, int maxCapacity);

咱们回到缓冲区分配的方法:

public ByteBuf buffer() { if (directByDefault) { return directBuffer(); } return heapBuffer(); }

刚才简单剖析了directBuffer()的分配, 如今在继续跟到heapBuffer(), 看其分配heap类型的ByteBuf的抽象逻辑:

public ByteBuf heapBuffer() { return heapBuffer(DEFAULT_INITIAL_CAPACITY, Integer.MAX_VALUE); }

这里一样调用了重载的heapBuffer, 并传入了初始容量和最大容量

再继续跟heapBuffer方法:

public ByteBuf heapBuffer(int initialCapacity, int maxCapacity) { if (initialCapacity == 0 && maxCapacity == 0) { return emptyBuf; } validate(initialCapacity, maxCapacity); return newHeapBuffer(initialCapacity, maxCapacity); }

一样, 这里若是初始容量和最大容量都为空的话, 返回一个表明空的ByteBuf

而后经过validate方法进行参数验证

最后经过newHeapBuffer方法建立一个新的heap类型的ByteBuf

一样, newHeapBuffer方法在AbstractByteBufAllocator中也是一个抽象方法, 具体逻辑交给其子类实现

protected abstract ByteBuf newHeapBuffer(int initialCapacity, int maxCapacity);

 

 

newDirectBuffernewHeapBuffer两个抽象方法中, 在其子类PooledByteBufAllocatorUnpooledByteBufAllocator中都有实现

咱们以UnpooledByteBufAllocatornewHeapBuffer方法为例, 看其实现:

protected ByteBuf newHeapBuffer(int initialCapacity, int maxCapacity) { return PlatformDependent.hasUnsafe() ? new UnpooledUnsafeHeapByteBuf(this, initialCapacity, maxCapacity) : new UnpooledHeapByteBuf(this, initialCapacity, maxCapacity); }

里实现方式其实很简单, 首先经过PlatformDependent.hasUnsafe()判断当前运行环境是否能建立unsafe对象, 若是能, 则直接经过new UnpooledUnsafeHeapByteBuf(this, initialCapacity, maxCapacity)方式建立一个UnpooledUnsafeHeapByteBuf对象, 也就是一个UnsafeByteBuf对象

 

若是当前环境不能建立unsafe对象, 则经过new UnpooledHeapByteBuf(this, initialCapacity, maxCapacity)这种方方式建立一个UnpooledHeapByteBuf对象, 也就是非UnsafeByteBuf对象

从这里能看出, 其实在建立ByteBuf对象时, 是否建立unsafe类型的对象并非咱们本身控制的, 而是经过程序判断当前环境来决定是否建立unsafe类型的ByteBuf对象的

 

有关ByteBufAllocator的继承关系以下:

5-3-1

 

上一节: ByteBuf的分类

下一节: PooledByteBufAllocator简述

相关文章
相关标签/搜索