您好,登錄后才能下訂單哦!
這篇文章主要介紹C++ 中boost::share_ptr智能指針怎么用,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
C++ 中boost::share_ptr智能指針的使用方法
最近項目中使用boost庫的智能指針,感覺智能指針還是蠻強大的,在此貼出自己學習過程中編寫的測試代碼,以供其他想了解boost智能指針的朋友參考,有講得不正確之處歡迎指出討論。當然,使用boost智能指針首先要編譯boost庫,具體方法可以網上查詢,在此不再贅述。
智能指針能夠使C++的開發簡單化,主要是它能夠自動管理內存的釋放,而且能夠做更多的事情,即使用智能指針,則可以再代碼中new了之后不用delete,智能指針自己會幫助你管理內存資源的釋放。
Boost庫的智能指針有很多種,下面通過示例代碼來說明其中share_ptr的使用方法。
/ test.cpp : Defines the entry point for the console application. #include "stdafx.h" #include <iostream> #include <boost/shared_ptr.hpp> #include <vector> /** 測試類 */ class CTest { public: /** 構造函數 */ CTest(int m) { m_member = m; /** 申請空間 */ m_pname = new char[2]; } /** 析構函數 */ ~CTest() { delete m_pname; } /** 成員函數 */ int getMember() { return m_member; } private: /** 數據成員 */ int m_member; char * m_pname; }; int _tmain(int argc, _TCHAR* argv[]) { /** 示例代碼【1】 */ /** boost::shared_ptr智能指針含有一個引用計數器 */ /** 引用指針計數器記錄有多少個引用指針指向同一個對象,如果最后一個引用指針被銷毀的時候,那么就銷毀對象本身。 */ /** 使用智能指針創建一個對象 */ /** 注意: 智能指針不支持直接 new 例如: boost::shared_ptr<CTest> pTemp = new CTest(2) 是錯誤的 */ boost::shared_ptr<CTest> pTemp(new CTest(10)); /** 創建一個新的智能指針也指向新創建的CTest對象 */ /** 智能指針支持等號操作 */ boost::shared_ptr<CTest> pSecond = pTemp; /** 通過智能指針訪問該對象 */ std::cout << pTemp->getMember() << std::endl; /** 讓第一個智能指針為空,不再指向該對象,注意,智能指針不能使用 pTemp = NULL */ pTemp.reset(); /** 讓第二個智能指針也為空,這時該CTest對象已經沒有智能指針指向它了,會自動析構 */ pSecond.reset(); /** 示例代碼【2】 */ /** 將一個普通的指針轉換為智能指針 */ /** 創建一個普通的指針,new一個對象 */ CTest * pATest = new CTest(100); /** 轉換為智能指針 */ boost::shared_ptr<CTest> pShareTest(pATest); /** 智能指針會自動管理創建的CTest對象,不允許再進行delete,否則程序會掛掉 */ delete pATest; /** 讓智能指針為空,則對象會被自動析構 */ pShareTest.reset(); /** 示例代碼【3】 */ /** 創建一個容器存放智能指針 */ /** 這里需要注意: 兩個“ > ” 不要寫到一起了,否則會產生 >> 運算符重載 */ std::vector<boost::shared_ptr<CTest> > vec; /** 創建一個臨時的CTest對象,存放到上面的容器 */ { /** 使用智能指針創建一個對象 */ boost::shared_ptr<CTest> pTemp(new CTest(2)); /** 添加到容器中 */ vec.push_back(pTemp); /** 離開大括號,則pTemp析構,于是只有容器中的指針指向了新創建的CTest */ } /** 讓vector迭代器指向剛剛push_back到容器中的智能指針 */ std::vector<boost::shared_ptr<CTest> >::iterator itor = vec.begin(); /** 訪問智能指針, (*itor)即為智能指針對象,指向了剛才創建的CTest,通過 -> 方法訪問CTest對象 */ std::cout << (*itor)->getMember()<<std::endl; /** 清空容器,在容器被清空時,容器中的智能指針被刪除, 由于此時已經沒有智能指針指向該對象,故該CTest對象會自動析構 */ vec.clear(); int temp; std::cin >> temp; return 0; } /** 使用智能指針需要注意的地方 */ // 1. 智能指針其實是一種類對象,并不是簡單的指針,故當智能指針包含另一個類的對象時, // 需要包含另一個類的頭文件,而不能簡單的使用前向引用聲明 // eg: CMyClass.h文件 #include "CTest.h" /** 不能簡單地使用前向引用聲明,必須包含頭文件 */ // 前向引用聲明 class CTest class CMyClass { public: private: boost::shared_ptr<CTest> m_pTest; }; // 2. shared_ptr 是線程安全的 // 3. 使用智能指針出現循環引用的情況 // 即兩個類互相含有對方類對象的智能指針
以上是“C++ 中boost::share_ptr智能指針怎么用”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。