shared_ptr很好地消除了顯式的delete調用,如果讀者掌握了它的用法,可以肯定delete將會在你的編程字典中徹底消失 。
但這還不夠,因為shared_ptr的構造還需要new調用,這導致了代碼中的某種不對稱性。雖然shared_ptr很好地包裝了new表達式,但過多的顯式new操作符也是個問題,它應該使用工廠模式來解決。
因此,shared_ptr在頭文件<boost/make_shared.hpp> 中提供了一個自由工廠函數(位於boost名字空間)make_shared<T>(),來消除顯式的new調用,它的名字模仿了標准庫的 make_pair(),聲明如下:
- template<class
T, >class... Args -
<T>shared_ptr make_shared( Args && ... args );
make_shared()函數可以接受最多10個參數,然后把它們傳遞給類型T的構造函數,創建一個shared_ptr<T>的對 象並返回。make_shared()函數要比直接創建shared_ptr對象的方式快且高效,因為它內部僅分配一次內存,消除了shared_ptr 構造時的開銷。
下面的代碼示范了make_shared()函數的用法:
- #include
<boost/make_shared.hpp> - int
main() - {
-
<string>shared_ptr sp = -
make_shared<string>("make_shared");
//創建string的共享指針 -
<vector<int>shared_ptr > spv = -
make_shared<vector<int>>(10, 2);
//創建vector的共享指針 -
>size()assert(spv- == 10); - }
- #include <boost/smart_ptr.hpp>
- int main()
- {
- boost::shared_ptr<string> sp(new string("shared_ptr"));
- cout << *sp << endl;
- cout << sp->size() << endl;
- }
make_shared()不能接受任意多數量的參數構造對象,一般情況下這不會成為問題。實際上,很少有如此多的參數的函數接口,即使有,那也會是一個設計的不夠好的接口,應該被重構。
除了make_shared(),smart_ptr庫還提供一個allocate_shared(),它比make_ shared()多接受一個定制的內存分配器類型參數,其他方面都相同。
