日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

面試官:說說Netty對象池的實現原理?

來源: 責編: 時間:2024-06-05 17:44:42 139觀看
導讀Netty 作為一個高性能的網絡通訊框架,它內置了很多恰奪天工的設計,目的都是為了將網絡通訊的性能做到極致,其中「對象池技術」也是實現這一目標的重要技術。1.什么是對象池技術?對象池技術是一種重用對象以減少對象創建和

x5e28資訊網——每日最新資訊28at.com

Netty 作為一個高性能的網絡通訊框架,它內置了很多恰奪天工的設計,目的都是為了將網絡通訊的性能做到極致,其中「對象池技術」也是實現這一目標的重要技術。x5e28資訊網——每日最新資訊28at.com

1.什么是對象池技術?

對象池技術是一種重用對象以減少對象創建和銷毀帶來的開銷的方法。在對象池中,只有第一次訪問時會創建對象,并將其維護在內存中,當再次需要使用對象時,會直接從對象池中獲取對象,并在使用完畢后歸還給對象池,而不是頻繁地創建和銷毀對象。x5e28資訊網——每日最新資訊28at.com

使用對象池技術的優點有以下幾個:x5e28資訊網——每日最新資訊28at.com

  • 提高性能:復用對象可以減少對象的創建和銷毀次數,降低系統開銷,提高系統性能和吞吐量。
  • 減少內存碎片:對象池可以避免頻繁地創建和銷毀對象,減少內存碎片的產生,提高內存利用率。
  • 避免頻繁GC:減少了對象的創建和銷毀,可以減少垃圾回收(GC)的頻率,降低系統的負擔,提高系統的穩定性。

2.對象池基本使用

Netty 對象池技術的核心實現類為 Recycler,Recycler 主要提供了以下 3 個方法:x5e28資訊網——每日最新資訊28at.com

  • get():獲取一個可重復使用的對象,如果對象池中有空閑對象,則返回其中一個;否則會創建一個新對象。
  • recycle(T, Handle):回收一個對象,將對象放回對象池中以便下次復用。
  • newObject(Handle):當對象池中沒有可用對象時,此方法會被調用以創建新的對象實例。

接下來我們寫一個 Recycler 對象池的使用 Demo,假設我們有一個 User 類,需要實現 User 對象的復用,具體實現代碼如下:x5e28資訊網——每日最新資訊28at.com

public class UserRecyclerDemo {    private static final Recycler<User> userRecycler = new Recycler<User>() {        @Override        protected User newObject(Handle<User> handle) {            return new User(handle);        }    };    static final class User {        private String name;        private Recycler.Handle<User> handle;        public void setName(String name) {            this.name = name;        }        public String getName() {            return name;        }        public User(Recycler.Handle<User> handle) {            this.handle = handle;        }        public void recycle() {            handle.recycle(this);        }    }    public static void main(String[] args) {        User user1 = userRecycler.get();  // 1.從對象池獲取 User 對象        user1.setName("zhangsan");    // 2.設置 User 對象的屬性        user1.recycle();      // 3.回收對象到對象池        User user2 = userRecycler.get();  // 4.從對象池獲取對象        System.out.println(user1 == user2);        System.out.println(user2.getName());    }}

以上程序的執行結果如下:x5e28資訊網——每日最新資訊28at.com

truex5e28資訊網——每日最新資訊28at.com

zhangsanx5e28資訊網——每日最新資訊28at.com

從上述結果可以看出,當第一次調用 userRecycler.get() 時,因為對象池中尚未存在 user 對象,所以創建了 name 為“zhangsan”的對象。但第二次再調用 userRecycler.get() 時,因為對象池中已經存在了 user 對象,所以直接從對象池中取出了 user 對象,所以 user1==user2 時,得到的結果是 true。x5e28資訊網——每日最新資訊28at.com

3.對象池技術應用

在 Netty 中,使用 Recycler 對象池管理對象的常見類有以下幾個:x5e28資訊網——每日最新資訊28at.com

  • PooledHeapByteBuf:管理堆內存中的 ByteBuf 對象。
  • PooledDirectByteBuf:管理堆外內存中的 ByteBuf 對象。
  • ChannelOutboundBuffer.Entry:Netty 出站緩沖區(ChannelOutboundBuffer)中,每一個待發送的消息都包裝在一個 Entry 對象中。

4.實現原理

要搞清楚 Netty 對象池技術的實現原理,就要搞清楚 Netty 對象池的核心組件,以及組件之間的關系。x5e28資訊網——每日最新資訊28at.com

Netty 對象池技術的實現依靠以下 4 大組件:x5e28資訊網——每日最新資訊28at.com

  • Stack(棧):每個線程都關聯一個 Stack(使用 FastThreadLocal 進行存儲),用于存儲和管理該線程回收的對象。Stack 中存儲的是 DefaultHandle 對象,這些 DefaultHandle 對象包裝了實際要重用的對象。Stack 是與線程綁定的,每個線程從自己的 Stack 中獲取對象。
  • WeakOrderQueue(弱序隊列):當某個線程(非主線程)回收對象時,這些對象不會直接放入主線程的 Stack 中,而是放入 WeakOrderQueue 中。WeakOrderQueue 存儲的是從其他線程回收的對象,這些對象被包裝在 DefaultHandle 中。WeakOrderQueue 與 Stack 關聯,但屬于非主線程。當主線程的 Stack 為空時,會嘗試從 WeakOrderQueue 中獲取對象。
  • Link(鏈表):WeakOrderQueue 中的存儲單元,用于存儲回收的對象。Link 中存儲的是 DefaultHandle 對象數組,這些數組包含從其他線程回收的對象。
  • DefaultHandle:對象的包裝類,在 Recycler 中緩存的對象都會包裝成 DefaultHandle 類。DefaultHandle 中存儲了實際要重用的對象,以及與之相關的元數據。

簡單來說,這 4 個組件的關系是,(每個)線程為了保證線程安全和高效性操作,所以會把使用的對象放到 Stack 棧中,且每個線程都有自己的 Stack 棧。當線程中的對象不再被使用時(也就是被回收時),并不會將回收對象直接放到 Stack 中(因為當前線程已經不再使用了),此時會將對象存放到 WeakOrderQueue 隊列中,因為 WeakOrderQueue 隊列相當于“線程共享的區域”,這樣其他線程就可以方便的從 WeakOrderQueue 中獲取對象進行重用了。而 WeakOrderQueue 中的存儲單元是 Link 鏈表,它存儲的是對象池中的包裝對象 DefaultHandle,這就是這四大核心組件之間的關系。x5e28資訊網——每日最新資訊28at.com

5.線程如何獲取對象?

在 Netty 中,獲取對象池中對象的流程如下:x5e28資訊網——每日最新資訊28at.com

  • 判斷 Stack:線程首先會嘗試從自己的 Stack 中獲取對象。如果 Stack 中有對象,則直接彈出(pop)并返回。
  • Stack 為空:如果 Stack 為空,線程會檢查 WeakOrderQueue。如果 WeakOrderQueue 中有對象,則按照一定的規則(如“1/7規則”,每 7 個移動 1 個)將部分對象轉移到 Stack 中,然后從 Stack 中彈出并返回。
  • 創建新對象:如果 Stack 和 WeakOrderQueue 都為空,線程會調用 newObject() 方法創建一個新的對象,并包裝成 DefaultHandle 后放入 Stack 中,然后返回該對象。

通過這樣的設計,Netty 的 Recycler 對象池技術能夠高效地重用對象,減少內存分配和垃圾收集的開銷,提升性能。x5e28資訊網——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-92142-0.html面試官:說說Netty對象池的實現原理?

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Python性能加速器:深度解析__slots__屬性優化內存利用!

下一篇: 2024 年你可以使用的十大 Node.js 現代特性

標簽:
  • 熱門焦點
Top 主站蜘蛛池模板: 盘锦市| 二连浩特市| 临沭县| 句容市| 平乐县| 沂南县| 墨玉县| 闸北区| 南汇区| 翼城县| 永泰县| 车险| 哈尔滨市| 杭州市| 广元市| 平乐县| 屏东县| 新丰县| 丰顺县| 阿拉善左旗| 云南省| 高阳县| 通州区| 高平市| 自治县| 福建省| 绥阳县| 乌苏市| 桃江县| 旬邑县| 平阴县| 衡南县| 武山县| 陕西省| 喀喇| 夏河县| 轮台县| 谢通门县| 永和县| 香港 | 高安市|