|
shared_ptr的作用有如同指針,但會(huì)記錄有多少個(gè)shared_ptrs共同指向一個(gè)對(duì)象。這便是所謂的引用計(jì)數(shù)(reference counting)。一旦最后一個(gè)這樣的指針被銷毀,也就是一旦某個(gè)對(duì)象的引用計(jì)數(shù)變?yōu)?,這個(gè)對(duì)象會(huì)被自動(dòng)刪除。shared_ptr 在 Technique report I 中已經(jīng)出現(xiàn),在effective C++ 中提到過shared_ptr 的使用,現(xiàn)在已經(jīng)成為C++11 的正式成員。shared_ptr 的自動(dòng)刪除功能是一個(gè)很好的防止內(nèi)存泄露的方法,在C++中也稱為RAII(Resource Acquisition Is Initialization)。RAII 的一般做法是這樣的:在對(duì)象構(gòu)造時(shí)獲取資源,接著控制對(duì)資源的訪問使之在對(duì)象的生命周期內(nèi)始終保持有效,最后在對(duì)象析構(gòu)的時(shí)候釋放資源。借此,我們實(shí)際上把管理一份資源的責(zé)任托管給了一個(gè)對(duì)象。這種做法有兩大好處:1,我們不需要顯式地釋放資源。2,采用這種方式,對(duì)象所需的資源在其生命期內(nèi)始終保持有效 —— 我們可以說,此時(shí)這個(gè)類維護(hù)了一個(gè) invariant。這樣,通過該類對(duì)象使用資源時(shí),就不必檢查資源有效性的問題,可以簡化邏輯、提高效率。 下面來看一個(gè)簡單的例子,涵蓋了shared_ptr的基本操作: #include <memory> #include <iostream> int main() { auto sp1 = std::make_shared<int>(5); std::cout << "sp1.unique() == " << std::boolalpha << sp1.unique() << std::endl; std::shared_ptr<int> sp2 = sp1; std::cout << "sp1.unique() == " << std::boolalpha << sp1.unique() << std::endl; std::cout << "sp1.use_count(): "<< sp1.use_count()<<std::endl; std::cout << "sp2.use_count(): "<< sp2.use_count()<<std::endl; std::cout <<"sp1.get(): "<<sp1.get()<<std::endl; std::cout <<"sp2.get(): "<<sp2.get()<<std::endl; sp1.reset(); std::cout << "sp1.use_count(): "<< sp1.use_count()<<std::endl; std::cout << "sp2.use_count(): "<< sp2.use_count()<<std::endl; std::shared_ptr<int> sp3(new int(10)); std::cout <<"*sp2: "<< *sp2 <<std::endl; std::cout <<"*sp3: "<< *sp3 <<std::endl; sp2.swap(sp3); std::cout <<"After swap: "<<std::endl; std::cout <<"*sp2: "<< *sp2 <<std::endl; std::cout <<"*sp3: "<< *sp3 <<std::endl; } 運(yùn)行結(jié)果: C:\Windows\system32\cmd.exe /c shared_ptr.exe 說明:unique 函數(shù) 判斷該指針的引用計(jì)數(shù)是否為1,use_count() 函數(shù)返回該指針的引用計(jì)數(shù),get()函數(shù)返回該指針的值,reset()清除該指針的引用計(jì)數(shù),swap()函數(shù)交換兩個(gè)指針的值。 |
|
|