http://ticktick.blog.51cto.com/823160/196765
最近項目中使用boost庫的智能指針,感覺智能指針還是蠻強大的,在此貼出自己學習過程中編寫的測試代碼,以供其他想了解boost智能指針的朋友參考,有講得不正確之處歡迎指出討論。當然,使用boost智能指針首先要編譯boost庫,具體方法可以網上查詢,在此不再贅述。
智能指針能夠使C++的開發簡單化,主要是它能夠自動管理內存的釋放,而且能夠做更多的事情,即使用智能指針,則可以再代碼中new了之後不用delete,智能指針自己會幫助你管理內存資源的釋放。
Boost庫的智能指針有很多種,下面通過示例代碼來說明其中share_ptr的使用方法。
#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