C++ 中boost::share_ptr智能指針的使用方法
C++ 中boost::share_ptr智能指針的使用方法
最近項目中使用boost庫的智能指針,感覺智能指針還是蠻強(qiáng)大的,在此貼出自己學(xué)習(xí)過程中編寫的測試代碼,以供其他想了解boost智能指針的朋友參考,有講得不正確之處歡迎指出討論。當(dāng)然,使用boost智能指針首先要編譯boost庫,具體方法可以網(wǎng)上查詢,在此不再贅述。
智能指針能夠使C++的開發(fā)簡單化,主要是它能夠自動管理內(nèi)存的釋放,而且能夠做更多的事情,即使用智能指針,則可以再代碼中new了之后不用delete,智能指針自己會幫助你管理內(nèi)存資源的釋放。
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:
/** 構(gòu)造函數(shù) */
CTest(int m)
{
m_member = m;
/** 申請空間 */
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智能指針含有一個引用計數(shù)器 */
/** 引用指針計數(shù)器記錄有多少個引用指針指向同一個對象,如果最后一個引用指針被銷毀的時候,那么就銷毀對象本身。 */
/** 使用智能指針創(chuàng)建一個對象 */
/** 注意: 智能指針不支持直接 new 例如: boost::shared_ptr<CTest> pTemp = new CTest(2) 是錯誤的 */
boost::shared_ptr<CTest> pTemp(new CTest(10));
/** 創(chuàng)建一個新的智能指針也指向新創(chuàng)建的CTest對象 */
/** 智能指針支持等號操作 */
boost::shared_ptr<CTest> pSecond = pTemp;
/** 通過智能指針訪問該對象 */
std::cout << pTemp->getMember() << std::endl;
/** 讓第一個智能指針為空,不再指向該對象,注意,智能指針不能使用 pTemp = NULL */
pTemp.reset();
/** 讓第二個智能指針也為空,這時該CTest對象已經(jīng)沒有智能指針指向它了,會自動析構(gòu) */
pSecond.reset();
/** 示例代碼【2】 */
/** 將一個普通的指針轉(zhuǎn)換為智能指針 */
/** 創(chuàng)建一個普通的指針,new一個對象 */
CTest * pATest = new CTest(100);
/** 轉(zhuǎn)換為智能指針 */
boost::shared_ptr<CTest> pShareTest(pATest);
/** 智能指針會自動管理創(chuàng)建的CTest對象,不允許再進(jìn)行delete,否則程序會掛掉 */
delete pATest;
/** 讓智能指針為空,則對象會被自動析構(gòu) */
pShareTest.reset();
/** 示例代碼【3】 */
/** 創(chuàng)建一個容器存放智能指針 */
/** 這里需要注意: 兩個“ > ” 不要寫到一起了,否則會產(chǎn)生 >> 運算符重載 */
std::vector<boost::shared_ptr<CTest> > vec;
/** 創(chuàng)建一個臨時的CTest對象,存放到上面的容器 */
{
/** 使用智能指針創(chuàng)建一個對象 */
boost::shared_ptr<CTest> pTemp(new CTest(2));
/** 添加到容器中 */
vec.push_back(pTemp);
/** 離開大括號,則pTemp析構(gòu),于是只有容器中的指針指向了新創(chuàng)建的CTest */
}
/** 讓vector迭代器指向剛剛push_back到容器中的智能指針 */
std::vector<boost::shared_ptr<CTest> >::iterator itor = vec.begin();
/** 訪問智能指針, (*itor)即為智能指針對象,指向了剛才創(chuàng)建的CTest,通過 -> 方法訪問CTest對象 */
std::cout << (*itor)->getMember()<<std::endl;
/** 清空容器,在容器被清空時,容器中的智能指針被刪除,
由于此時已經(jīng)沒有智能指針指向該對象,故該CTest對象會自動析構(gòu) */
vec.clear();
int temp;
std::cin >> temp;
return 0;
}
/** 使用智能指針需要注意的地方 */
// 1. 智能指針其實是一種類對象,并不是簡單的指針,故當(dāng)智能指針包含另一個類的對象時,
// 需要包含另一個類的頭文件,而不能簡單的使用前向引用聲明
// eg: CMyClass.h文件
#include "CTest.h"
/** 不能簡單地使用前向引用聲明,必須包含頭文件 */
// 前向引用聲明 class CTest
class CMyClass
{
public:
private:
boost::shared_ptr<CTest> m_pTest;
};
// 2. shared_ptr 是線程安全的
// 3. 使用智能指針出現(xiàn)循環(huán)引用的情況
// 即兩個類互相含有對方類對象的智能指針
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
OpenMP中For Construct對dynamic的調(diào)度方式詳解
在本篇文章當(dāng)中主要給大家介紹 OpenMp for construct 的實現(xiàn)原理,與他相關(guān)的動態(tài)庫函數(shù)分析以及對 dynamic 的調(diào)度方式進(jìn)行分析,希望對大家有所幫助2023-02-02
Linux?C/C++?timeout命令實現(xiàn)運行具有時間限制功能
inux?timeout命令的一個屬性是時間限制??梢詾槿魏蚊钤O(shè)置時間限制。如果時間到期,命令將停止執(zhí)行,這篇文章主要介紹了Linux?C/C++?timeout命令實現(xiàn)(運行具有時間限制),需要的朋友可以參考下2023-02-02
linux c程序中獲取shell腳本輸出的實現(xiàn)方法
以下是對在linux下c程序中獲取shell腳本輸出的實現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-08-08
詳解C++ STL vector容量(capacity)和大小(size)的區(qū)別
這篇文章主要介紹了詳解C++ STL vector容量(capacity)和大小(size)的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05

