Netty分布式ByteBuf緩沖區(qū)分配器源碼解析
緩沖區(qū)分配器
顧明思議就是分配緩沖區(qū)的工具, 在netty中, 緩沖區(qū)分配器的頂級抽象是接口ByteBufAllocator, 里面定義了有關(guān)緩沖區(qū)分配的相關(guān)api
抽象類AbstractByteBufAllocator實(shí)現(xiàn)了ByteBufAllocator接口, 并且實(shí)現(xiàn)了其大部分功能
和AbstractByteBuf一樣, AbstractByteBufAllocator也實(shí)現(xiàn)了緩沖區(qū)分配的骨架邏輯, 剩余的交給其子類
以其中的分配ByteBuf的方法為例, 對其做簡單的介紹
public ByteBuf buffer() { if (directByDefault) { return directBuffer(); } return heapBuffer(); }
這里if (directByDefault)會判斷默認(rèn)創(chuàng)建的ByteBuf是不是一個基于直接內(nèi)存的ByteBuf, 也就是direct類型的ByteBuf, 如果是, 則通過directBuffer()方法返回direct類型的ByteBuf, 否則, 會通過heapBuffer()返回heap類型的ByteBuf
跟到directBuffer()方法中
public ByteBuf directBuffer() { return directBuffer(DEFAULT_INITIAL_CAPACITY, Integer.MAX_VALUE); }
這里又調(diào)用了一個重載directBuffer方法, 其中DEFAULT_INITIAL_CAPACITY代表分配的默認(rèn)容量, Integer.MAX_VALUE表示分配的ByteBuf可擴(kuò)容的最大容量, 也就是Integer類型的最大值, 我們再跟進(jìn)去:
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方法進(jìn)行參數(shù)驗(yàn)證
最后newDirectBuffer創(chuàng)建一個Direct類型的ByteBuf, 并將初始容量和最大容量傳入
在AbstractByteBufAllocator中, newDirectBuffer是一個抽象方法, 由其子類實(shí)現(xiàn)
protected abstract ByteBuf newDirectBuffer(int initialCapacity, int maxCapacity);
我們回到緩沖區(qū)分配的方法
public ByteBuf buffer() { if (directByDefault) { return directBuffer(); } return heapBuffer(); }
剛才簡單剖析了directBuffer()的分配, 現(xiàn)在在繼續(xù)跟到heapBuffer()中, 看其分配heap類型的ByteBuf的抽象邏輯:
public ByteBuf heapBuffer() { return heapBuffer(DEFAULT_INITIAL_CAPACITY, Integer.MAX_VALUE); }
這里同樣調(diào)用了重載的heapBuffer, 并傳入了初始容量和最大容量
再繼續(xù)跟heapBuffer方法:
public ByteBuf heapBuffer(int initialCapacity, int maxCapacity) { if (initialCapacity == 0 && maxCapacity == 0) { return emptyBuf; } validate(initialCapacity, maxCapacity); return newHeapBuffer(initialCapacity, maxCapacity); }
同樣, 這里如果初始容量和最大容量都為空的話, 返回一個代表空的ByteBuf
然后通過validate方法進(jìn)行參數(shù)驗(yàn)證
最后通過newHeapBuffer方法創(chuàng)建一個新的heap類型的ByteBuf
同樣, newHeapBuffer方法在AbstractByteBufAllocator中也是一個抽象方法, 具體邏輯交給其子類實(shí)現(xiàn)
protected abstract ByteBuf newHeapBuffer(int initialCapacity, int maxCapacity);
newDirectBuffer和newHeapBuffer兩個抽象方法中, 在其子類PooledByteBufAllocator和UnpooledByteBufAllocator中都有實(shí)現(xiàn)
我們以UnpooledByteBufAllocator的newHeapBuffer方法為例, 看其實(shí)現(xiàn):
protected ByteBuf newHeapBuffer(int initialCapacity, int maxCapacity) { return PlatformDependent.hasUnsafe() ? new UnpooledUnsafeHeapByteBuf(this, initialCapacity, maxCapacity) : new UnpooledHeapByteBuf(this, initialCapacity, maxCapacity); }
里實(shí)現(xiàn)方式其實(shí)很簡單, 首先通過PlatformDependent.hasUnsafe()判斷當(dāng)前運(yùn)行環(huán)境是否能創(chuàng)建unsafe對象, 如果能, 則直接通過new UnpooledUnsafeHeapByteBuf(this, initialCapacity, maxCapacity)方式創(chuàng)建一個UnpooledUnsafeHeapByteBuf對象, 也就是一個Unsafe的ByteBuf對象
如果當(dāng)前環(huán)境不能創(chuàng)建unsafe對象, 則通過new UnpooledHeapByteBuf(this, initialCapacity, maxCapacity)這種方方式創(chuàng)建一個UnpooledHeapByteBuf對象, 也就是非Unsafe的ByteBuf對象
從這里能看出, 其實(shí)在創(chuàng)建ByteBuf對象時, 是否創(chuàng)建unsafe類型的對象并不是我們自己控制的, 而是通過程序判斷當(dāng)前環(huán)境來決定是否創(chuàng)建unsafe類型的ByteBuf對象的
有關(guān)ByteBufAllocator的繼承關(guān)系如下:
以上就是Netty分布式ByteBuf緩沖區(qū)分配器源碼解析的詳細(xì)內(nèi)容,更多關(guān)于Netty分布式ByteBuf緩沖區(qū)分配器的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
淺談使用java實(shí)現(xiàn)阿里云消息隊(duì)列簡單封裝
這篇文章主要介紹了淺談使用java實(shí)現(xiàn)阿里云消息隊(duì)列簡單封裝,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03Spring?JPA使用CriteriaBuilder動態(tài)構(gòu)造查詢方式
這篇文章主要介紹了Spring?JPA使用CriteriaBuilder動態(tài)構(gòu)造查詢方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12Javaweb實(shí)戰(zhàn)之實(shí)現(xiàn)蛋糕訂購系統(tǒng)
隨著網(wǎng)絡(luò)的普及與發(fā)展,網(wǎng)上購物逐漸成為一種主流消費(fèi)的方式。這篇文章主要介紹了通過JavaWeb制作一個線上蛋糕訂購系統(tǒng),文中示例代碼講解詳細(xì),需要的朋友可以參考一下2021-12-12java中String StringBuffer和StringBuilder的區(qū)別詳解
大家好,本篇文章主要講的是java中String StringBuffer和StringBuilder的區(qū)別詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下2022-01-01java數(shù)據(jù)結(jié)構(gòu)和算法學(xué)習(xí)之漢諾塔示例
這篇文章主要介紹了java數(shù)據(jù)結(jié)構(gòu)和算法中的漢諾塔示例,需要的朋友可以參考下2014-02-02java?設(shè)計(jì)模式從風(fēng)控鏈理解責(zé)任鏈模式
這篇文章主要為大家介紹了java?設(shè)計(jì)模式從風(fēng)控鏈理解責(zé)任鏈模式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05Java實(shí)戰(zhàn)之基于I/O流設(shè)計(jì)的圖書管理系統(tǒng)
這篇文章主要介紹了Java實(shí)戰(zhàn)之基于I/O流設(shè)計(jì)的圖書館管理系統(tǒng),文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java的小伙伴們有非常好的幫助,需要的朋友可以參考下2021-04-04