最近項目中使用boost庫的智能指針,感受智能指針仍是蠻強大的,在此貼出本身學習過程當中編寫的測試代碼,以供其餘想了解boost智能指針的朋友參考,有講得不正確之處歡迎指出討論。固然,使用boost智能指針首先要編譯boost庫,具體方法能夠網上查詢,在此再也不贅述。
智能指針可以使C++的開發簡單化,主要是它可以自動管理內存的釋放,並且可以作更多的事情,即便用智能指針,則能夠再代碼中new了以後不用delete,智能指針本身會幫助你管理內存資源的釋放。
Boost庫的智能指針有不少種,下面經過示例代碼來講明其中share_ptr的使用方法。
html
/ 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. 使用智能指針出現循環引用的狀況 // 即兩個類互相含有對方類對象的智能指針 // 看下面這一篇文章Boost智能指針——weak_ptr 網址: http://www.cnblogs.com/TianFang/archive/2008/09/20/1294590.html