boost::share_ptr智能指針使用示例

最近項目中使用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
相關文章
相關標籤/搜索