C++ 中boost::share_ptr智能指針的使用方法
C++ 中boost::share_ptr智能指針的使用方法
最近項(xiàng)目中使用boost庫(kù)的智能指針,感覺(jué)智能指針還是蠻強(qiáng)大的,在此貼出自己學(xué)習(xí)過(guò)程中編寫的測(cè)試代碼,以供其他想了解boost智能指針的朋友參考,有講得不正確之處歡迎指出討論。當(dāng)然,使用boost智能指針首先要編譯boost庫(kù),具體方法可以網(wǎng)上查詢,在此不再贅述。
智能指針能夠使C++的開(kāi)發(fā)簡(jiǎn)單化,主要是它能夠自動(dòng)管理內(nèi)存的釋放,而且能夠做更多的事情,即使用智能指針,則可以再代碼中new了之后不用delete,智能指針自己會(huì)幫助你管理內(nèi)存資源的釋放。
Boost庫(kù)的智能指針有很多種,下面通過(guò)示例代碼來(lái)說(shuō)明其中share_ptr的使用方法。
/ test.cpp : Defines the entry point for the console application. #include "stdafx.h" #include <iostream> #include <boost/shared_ptr.hpp> #include <vector> /** 測(cè)試類 */ class CTest { public: /** 構(gòu)造函數(shù) */ CTest(int m) { m_member = m; /** 申請(qǐng)空間 */ m_pname = new char[2]; } /** 析構(gòu)函數(shù) */ ~CTest() { delete m_pname; } /** 成員函數(shù) */ int getMember() { return m_member; } private: /** 數(shù)據(jù)成員 */ int m_member; char * m_pname; }; int _tmain(int argc, _TCHAR* argv[]) { /** 示例代碼【1】 */ /** boost::shared_ptr智能指針含有一個(gè)引用計(jì)數(shù)器 */ /** 引用指針計(jì)數(shù)器記錄有多少個(gè)引用指針指向同一個(gè)對(duì)象,如果最后一個(gè)引用指針被銷毀的時(shí)候,那么就銷毀對(duì)象本身。 */ /** 使用智能指針創(chuàng)建一個(gè)對(duì)象 */ /** 注意: 智能指針不支持直接 new 例如: boost::shared_ptr<CTest> pTemp = new CTest(2) 是錯(cuò)誤的 */ boost::shared_ptr<CTest> pTemp(new CTest(10)); /** 創(chuàng)建一個(gè)新的智能指針也指向新創(chuàng)建的CTest對(duì)象 */ /** 智能指針支持等號(hào)操作 */ boost::shared_ptr<CTest> pSecond = pTemp; /** 通過(guò)智能指針訪問(wèn)該對(duì)象 */ std::cout << pTemp->getMember() << std::endl; /** 讓第一個(gè)智能指針為空,不再指向該對(duì)象,注意,智能指針不能使用 pTemp = NULL */ pTemp.reset(); /** 讓第二個(gè)智能指針也為空,這時(shí)該CTest對(duì)象已經(jīng)沒(méi)有智能指針指向它了,會(huì)自動(dòng)析構(gòu) */ pSecond.reset(); /** 示例代碼【2】 */ /** 將一個(gè)普通的指針轉(zhuǎn)換為智能指針 */ /** 創(chuàng)建一個(gè)普通的指針,new一個(gè)對(duì)象 */ CTest * pATest = new CTest(100); /** 轉(zhuǎn)換為智能指針 */ boost::shared_ptr<CTest> pShareTest(pATest); /** 智能指針會(huì)自動(dòng)管理創(chuàng)建的CTest對(duì)象,不允許再進(jìn)行delete,否則程序會(huì)掛掉 */ delete pATest; /** 讓智能指針為空,則對(duì)象會(huì)被自動(dòng)析構(gòu) */ pShareTest.reset(); /** 示例代碼【3】 */ /** 創(chuàng)建一個(gè)容器存放智能指針 */ /** 這里需要注意: 兩個(gè)“ > ” 不要寫到一起了,否則會(huì)產(chǎn)生 >> 運(yùn)算符重載 */ std::vector<boost::shared_ptr<CTest> > vec; /** 創(chuàng)建一個(gè)臨時(shí)的CTest對(duì)象,存放到上面的容器 */ { /** 使用智能指針創(chuàng)建一個(gè)對(duì)象 */ boost::shared_ptr<CTest> pTemp(new CTest(2)); /** 添加到容器中 */ vec.push_back(pTemp); /** 離開(kāi)大括號(hào),則pTemp析構(gòu),于是只有容器中的指針指向了新創(chuàng)建的CTest */ } /** 讓vector迭代器指向剛剛push_back到容器中的智能指針 */ std::vector<boost::shared_ptr<CTest> >::iterator itor = vec.begin(); /** 訪問(wèn)智能指針, (*itor)即為智能指針對(duì)象,指向了剛才創(chuàng)建的CTest,通過(guò) -> 方法訪問(wèn)CTest對(duì)象 */ std::cout << (*itor)->getMember()<<std::endl; /** 清空容器,在容器被清空時(shí),容器中的智能指針被刪除, 由于此時(shí)已經(jīng)沒(méi)有智能指針指向該對(duì)象,故該CTest對(duì)象會(huì)自動(dòng)析構(gòu) */ vec.clear(); int temp; std::cin >> temp; return 0; } /** 使用智能指針需要注意的地方 */ // 1. 智能指針其實(shí)是一種類對(duì)象,并不是簡(jiǎn)單的指針,故當(dāng)智能指針包含另一個(gè)類的對(duì)象時(shí), // 需要包含另一個(gè)類的頭文件,而不能簡(jiǎn)單的使用前向引用聲明 // eg: CMyClass.h文件 #include "CTest.h" /** 不能簡(jiǎn)單地使用前向引用聲明,必須包含頭文件 */ // 前向引用聲明 class CTest class CMyClass { public: private: boost::shared_ptr<CTest> m_pTest; }; // 2. shared_ptr 是線程安全的 // 3. 使用智能指針出現(xiàn)循環(huán)引用的情況 // 即兩個(gè)類互相含有對(duì)方類對(duì)象的智能指針
如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
C語(yǔ)言實(shí)現(xiàn)宿舍管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)宿舍管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06關(guān)于統(tǒng)計(jì)數(shù)字問(wèn)題的算法
本文介紹了統(tǒng)計(jì)數(shù)字問(wèn)題的算法,計(jì)算出書(shū)的全部頁(yè)碼中分別用到多少次數(shù)字0,1,2,3,.....9,并有每一步的解題思路,需要的朋友可以參考下2015-08-08