<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
顧明思議就是分配緩衝區的工具, 在netty中, 緩衝區分配器的頂級抽象是介面ByteBufAllocator, 裡面定義了有關緩衝區分配的相關api
抽象類AbstractByteBufAllocator實現了ByteBufAllocator介面, 並且實現了其大部分功能
和AbstractByteBuf一樣, AbstractByteBufAllocator也實現了緩衝區分配的骨架邏輯, 剩餘的交給其子類
public ByteBuf buffer() { if (directByDefault) { return directBuffer(); } return heapBuffer(); }
這裡if (directByDefault)會判斷預設建立的ByteBuf是不是一個基於直接記憶體的ByteBuf, 也就是direct型別的ByteBuf, 如果是, 則通過directBuffer()方法返回direct型別的ByteBuf, 否則, 會通過heapBuffer()返回heap型別的ByteBuf
public ByteBuf directBuffer() { return directBuffer(DEFAULT_INITIAL_CAPACITY, Integer.MAX_VALUE); }
這裡又呼叫了一個過載directBuffer方法, 其中DEFAULT_INITIAL_CAPACITY代表分配的預設容量, Integer.MAX_VALUE表示分配的ByteBuf可擴容的最大容量, 也就是Integer型別的最大值, 我們再跟進去:
public ByteBuf directBuffer(int initialCapacity, int maxCapacity) { if (initialCapacity == 0 && maxCapacity == 0) { return emptyBuf; } validate(initialCapacity, maxCapacity); return newDirectBuffer(initialCapacity, maxCapacity); }
這裡判斷如果初始容量和最大容量都為0的話, 則返回一個emptyBuf的成員變數, emptyBuf代表一個空的ByteBuf
然後通過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
最後通過newHeapBuffer方法建立一個新的heap型別的ByteBuf
同樣, newHeapBuffer方法在AbstractByteBufAllocator中也是一個抽象方法, 具體邏輯交給其子類實現
protected abstract ByteBuf newHeapBuffer(int initialCapacity, int maxCapacity);
newDirectBuffer和newHeapBuffer兩個抽象方法中, 在其子類PooledByteBufAllocator和UnpooledByteBufAllocator中都有實現
我們以UnpooledByteBufAllocator的newHeapBuffer方法為例, 看其實現:
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物件, 也就是一個Unsafe的ByteBuf物件
如果當前環境不能建立unsafe物件, 則通過new UnpooledHeapByteBuf(this, initialCapacity, maxCapacity)這種方方式建立一個UnpooledHeapByteBuf物件, 也就是非Unsafe的ByteBuf物件
從這裡能看出, 其實在建立ByteBuf物件時, 是否建立unsafe型別的物件並不是我們自己控制的, 而是通過程式判斷當前環境來決定是否建立unsafe型別的ByteBuf物件的
有關ByteBufAllocator的繼承關係如下:
以上就是Netty分散式ByteBuf緩衝區分配器原始碼解析的詳細內容,更多關於Netty分散式ByteBuf緩衝區分配器的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45