allocator java_netty-池化内存-PooledByteBufAllocator

PooledByteBufAllocator

89ceef3c5f0de7c618c8064f0089bbf7.png

属生

public static final PooledByteBufAllocator DEFAULT =

new PooledByteBufAllocator(PlatformDependent.directBufferPreferred());

private final PoolArena[] heapArenas; //一般是2倍CPU核心数

private final PoolArena[] directArenas;//一般是2倍CPU核心数

private final int tinyCacheSize;//512

private final int smallCacheSize;//256

private final int normalCacheSize;//64

private final List heapArenaMetrics;

private final List directArenaMetrics;

private final PoolThreadLocalCache threadCache;//线程局部变量

private final int chunkSize;//PoolChunk 的总内存

private final PooledByteBufAllocatorMetric metric;

内存分配

@Override

protected ByteBuf newDirectBuffer(int initialCapacity, int maxCapacity) {

PoolThreadCache cache = threadCache.get();//从线程局部变量获取一个,每个线程局部变量获取的对象不一样

PoolArena directArena = cache.directArena;//基本上每个核心的值不一样

final ByteBuf buf;

if (directArena != null) {

buf = directArena.allocate(cache, initialCapacity, maxCapacity);//分配

} else {

buf = PlatformDependent.hasUnsafe() ?

UnsafeByteBufUtil.newUnsafeDirectByteBuf(this, initialCapacity, maxCapacity) :

new UnpooledDirectByteBuf(this, initialCapacity, maxCapacity);

}

return toLeakAwareBuffer(buf);//追踪内存泄漏

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值