日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
深度剖析C++對(duì)象池自動(dòng)回收技術(shù)實(shí)現(xiàn)

對(duì)象池可以顯著提高性能,如果一個(gè)對(duì)象的創(chuàng)建非常耗時(shí)或非常昂貴,頻繁去創(chuàng)建的話會(huì)非常低效。對(duì)象池通過(guò)對(duì)象復(fù)用的方式來(lái)避免重復(fù)創(chuàng)建對(duì)象,它會(huì)事 先創(chuàng)建一定數(shù)量的對(duì)象放到池中,當(dāng)用戶需要?jiǎng)?chuàng)建對(duì)象的時(shí)候,直接從對(duì)象池中獲取即可,用完對(duì)象之后再放回到對(duì)象池中,以便復(fù)用。這種方式避免了重復(fù)創(chuàng)建耗 時(shí)或耗資源的大對(duì)象,大幅提高了程序性能。本文將探討對(duì)象池的技術(shù)特性以及源碼實(shí)現(xiàn)。

創(chuàng)新互聯(lián)主要從事成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)岳陽(yáng)樓,十余年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來(lái)電咨詢建站服務(wù):13518219792

對(duì)象池類圖

  • ObjectPool:管理對(duì)象實(shí)例的pool。

  • Client:使用者。

適用性:

  • 類的實(shí)例可重用。

  • 類的實(shí)例化過(guò)程開(kāi)銷較大。

  • 類的實(shí)例化的頻率較高。

效果:

  • 節(jié)省了創(chuàng)建類實(shí)例的開(kāi)銷。

  • 節(jié)省了創(chuàng)建類實(shí)例的時(shí)間。

  • 存儲(chǔ)空間隨著對(duì)象的增多而增大。

問(wèn)題

目前縱觀主流語(yǔ)言的實(shí)現(xiàn)方式無(wú)外乎3個(gè)步驟:

  1. 初始創(chuàng)建一定數(shù)量的對(duì)象池(也允許從外面添加對(duì)象)。

  2. 從對(duì)象池中取對(duì)象來(lái)使用。

  3. 用完之后返回對(duì)象池。

一般情況下這樣是OK的,可能存在的問(wèn)題是在第三步,有兩個(gè)問(wèn)題:

  1. 不方便,每次都需要顯式回收對(duì)象。

  2. 忘記將對(duì)象放回對(duì)象池,造成資源浪費(fèi)。

改進(jìn)動(dòng)機(jī)

解決顯式回收的問(wèn)題,實(shí)現(xiàn)自動(dòng)回收,省心省力。改進(jìn)之后的對(duì)象池?zé)o須提供release方法,對(duì)象會(huì)自動(dòng)回收,改進(jìn)之后的類圖如下。


技術(shù)內(nèi)幕

借助c++11智能指針,因?yàn)橹悄苤羔樋梢宰远x刪除器,在智能指針釋放的時(shí)候會(huì)調(diào)用刪除器,在刪除器中我們將用完的對(duì)象重新放回對(duì)象池。思路比較簡(jiǎn)單,但實(shí)現(xiàn)的時(shí)候需要考慮兩個(gè)問(wèn)題:

  1. 什么時(shí)候定義刪除器?

  2. 用shared_ptr還是unique_ptr?

1. 什么時(shí)候定義刪除器

自定義刪除器只做一件事,就是將對(duì)象重新放入對(duì)象池。如果對(duì)象池初始化的時(shí)候就自定義刪除器的話,刪除器中的邏輯是將對(duì)象放回對(duì)象池,放回的時(shí)候無(wú) 法再定義一個(gè)這樣的刪除器,所以這種做法行不通。需要注意,回收的對(duì)象只能是默認(rèn)刪除器的。除了前述原因之外,另外一個(gè)原因是對(duì)象池釋放的時(shí)候需要釋放所 有的智能指針,釋放的時(shí)候如果存在自定義刪除器將會(huì)導(dǎo)致對(duì)象無(wú)法刪除。只有在get的時(shí)候定義刪除器才行,但是初始創(chuàng)建或加入的智能指針是默認(rèn)刪除器,所 以我們需要把智能指針的默認(rèn)刪除器改為自定義刪除器。

1.2 用shared_ptr還是unique_ptr

因?yàn)槲覀冃枰阎悄苤羔樀哪J(rèn)刪除器改為自定義刪除器,用shared_ptr會(huì)很不方便,因?yàn)槟銦o(wú)法直接將shared_ptr的刪除器修改為自 定義刪除器,雖然你可以通過(guò)重新創(chuàng)建一個(gè)新對(duì)象,把原對(duì)象拷貝過(guò)來(lái)的做法來(lái)實(shí)現(xiàn),但是這樣做效率比較低。而unique_ptr由于是獨(dú)占語(yǔ)義,提供了一 種簡(jiǎn)便的方法方法可以實(shí)現(xiàn)修改刪除器,所以用unique_ptr是最適合的。

1.3 實(shí)現(xiàn)源碼

 
 
  1. #pragma once 
  2. #include  
  3. #include  
  4. #include  
  5.  
  6. template  
  7. class SimpleObjectPool 
  8. public: 
  9.     using DeleterType = std::function
  10.  
  11.     void add(std::unique_ptr t) 
  12.     { 
  13.         pool_.push_back(std::move(t)); 
  14.     } 
  15.  
  16.     std::unique_ptr get() 
  17.     { 
  18.         if (pool_.empty()) 
  19.         { 
  20.             throw std::logic_error("no more object"); 
  21.         } 
  22.  
  23.         //every time add custom deleter for default unique_ptr 
  24.         std::unique_ptr ptr(pool_.back().release(), [this](T* t) 
  25.         { 
  26.             pool_.push_back(std::unique_ptr(t)); 
  27.         }); 
  28.  
  29.         pool_.pop_back(); 
  30.         return std::move(ptr); 
  31.     } 
  32.  
  33.     bool empty() const 
  34.     { 
  35.         return pool_.empty(); 
  36.     } 
  37.  
  38.     size_t size() const 
  39.     { 
  40.         return pool_.size(); 
  41.     } 
  42.  
  43. private: 
  44.     std::vector> pool_; 
  45. }; 
  46.  
  47. //test code 
  48. void test_object_pool() 
  49.     SimpleObjectPool p; 
  50.     p.add(std::unique_ptr(new A())); 
  51.     p.add(std::unique_ptr(new A())); 
  52.     { 
  53.         auto t = p.get(); 
  54.         p.get(); 
  55.     } 
  56.  
  57.     { 
  58.         p.get(); 
  59.         p.get(); 
  60.     } 
  61.  
  62.     std::cout << p.size() << std::endl; 
  63. } 

如果你堅(jiān)持用shared_ptr,那么回收的時(shí)候你需要這樣寫:

 
 
  1. std::shared_ptr get() 
  2. if (pool_.empty()) 
  3.   throw std::logic_error("no more object"); 
  4.  
  5. std::shared_ptr ptr = pool_.back(); 
  6. auto p = std::shared_ptr(new T(std::move(*ptr.get())), [this](T* t) 
  7.   pool_.push_back(std::shared_ptr(t)); 
  8. }); 
  9.  
  10. //std::unique_ptr ptr(pool_.back().release(), [this](T* t) 
  11. //{ 
  12. // pool_.push_back(std::unique_ptr(t)); 
  13. //}); 
  14.  
  15. pool_.pop_back(); 
  16. return p; 

這種方式需要每次都創(chuàng)建一個(gè)新對(duì)象,并且拷貝原來(lái)的對(duì)象,是一種比較低效的做法。代碼僅僅是為了展示如何實(shí)現(xiàn)自動(dòng)回收對(duì)象,沒(méi)有考慮線程安全、對(duì)象池?cái)U(kuò)容策略等細(xì)節(jié),源碼鏈接:object_pool

總結(jié)凡是需要自動(dòng)回收的場(chǎng)景下都可以使用這種方式:在獲取對(duì)象的時(shí)候?qū)⒛J(rèn)刪除器改為自定義刪除器,確保它可以回收。注意,回收的智能指針使用的是 默認(rèn)刪除器,可以確保對(duì)象池釋放時(shí)能正常釋放對(duì)象。同時(shí)也將獲取對(duì)象和釋放對(duì)象時(shí),對(duì)象的控制權(quán)完全分離。其他的一些應(yīng)用場(chǎng)景:多例模式,無(wú)需手動(dòng)釋放, 自動(dòng)回收。


網(wǎng)站欄目:深度剖析C++對(duì)象池自動(dòng)回收技術(shù)實(shí)現(xiàn)
URL網(wǎng)址:
http://www.5511xx.com/article/dpgiohj.html