make_shared() shared_prt()詳解區別


shared_ptr很好地消除了顯式的delete調用,如果讀者掌握了它的用法,可以肯定delete將會在你的編程字典中徹底消失 。

但這還不夠,因為shared_ptr的構造還需要new調用,這導致了代碼中的某種不對稱性。雖然shared_ptr很好地包裝了new表達式,但過多的顯式new操作符也是個問題,它應該使用工廠模式來解決。

因此,shared_ptr在頭文件<boost/make_shared.hpp> 中提供了一個自由工廠函數(位於boost名字空間)make_shared<T>(),來消除顯式的new調用,它的名字模仿了標准庫的 make_pair(),聲明如下:

  1. template<class T, class... Args> 
  2.     shared_ptr<T> make_shared( Args && ... args ); 

make_shared()函數可以接受最多10個參數,然后把它們傳遞給類型T的構造函數,創建一個shared_ptr<T>的對 象並返回。make_shared()函數要比直接創建shared_ptr對象的方式快且高效,因為它內部僅分配一次內存,消除了shared_ptr 構造時的開銷。

下面的代碼示范了make_shared()函數的用法:

  1. #include <boost/make_shared.hpp> 
  2. int main()  
  3. {  
  4.     shared_ptr<string> sp =  
  5.                 make_shared<string>("make_shared");
    //創建string的共享指針  
  6.     shared_ptr<vector<int> > spv =  
  7.                 make_shared<vector<int> >(10, 2);      
    //創建vector的共享指針  
  8.     assert(spv->size() == 10);  
  9. #include <boost/smart_ptr.hpp>
  10. int main()
  11. {
  12.     boost::shared_ptr<string> sp(new string("shared_ptr"));
  13.     cout << *sp << endl;
  14.     cout << sp->size() << endl;
  15. }

make_shared()不能接受任意多數量的參數構造對象,一般情況下這不會成為問題。實際上,很少有如此多的參數的函數接口,即使有,那也會是一個設計的不夠好的接口,應該被重構。

除了make_shared(),smart_ptr庫還提供一個allocate_shared(),它比make_ shared()多接受一個定制的內存分配器類型參數,其他方面都相同。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM