• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            勤能補(bǔ)拙,Expter

            成都游戲Coder,記錄游戲開發(fā)過(guò)程的筆記和心得!

            智能指針(auto_ptr 和 shared_ptr)

            都是這周看書以及代碼的總結(jié):
              
                Stl  中 auto_ptr只是眾多可能的智能指針之一,auto_ptr所做的事情,就是動(dòng)態(tài)分配對(duì)象以及當(dāng)對(duì)象不再需要時(shí)自動(dòng)執(zhí)行清理。
                這里是一個(gè)簡(jiǎn)單的代碼示例,如果沒(méi)有auto_ptr,
                
               

             

             1void ProcessAdoption(istream &data)
             2{
             3 
             4    while (data)                            // 如果還有數(shù)據(jù)
             5    {
             6        ALA   *pa = readALAData(data);      // 取出下一個(gè)數(shù)據(jù)
             7        pa->DealProcessAdoption(data);        // 處理
             8 
             9        delete pa;                          // 釋放資源
            10    }

            11    return;
            12}


                 如果在DealProcessAdoption有一個(gè)exception,會(huì)發(fā)生什么事情,因?yàn)镻rocessAdoption不能捕獲他,所以這段代碼很危險(xiǎn),所以DealProcessAdoption后面的代碼可能會(huì)跳過(guò),造成內(nèi)存泄露。
            如果利用try catch去捕獲他,會(huì)搞得代碼很亂,又缺少美觀性。

            所以Stl提供了一個(gè)智能指針來(lái)解決這個(gè)問(wèn)題,我們可以先模擬實(shí)現(xiàn)一個(gè)智能指針的類實(shí)現(xiàn)。

             

             1// 關(guān)于一個(gè)智能指針的定義
             2template<typename Type>
             3class auto_ptr
             4{
             5public:
             6    auto_ptr(T *=NULL) :Ptr(p)
             7    {     }
             8    ~auto_ptr()
             9    {
            10        delete Ptr;
            11    }

            12private:
            13    Type *Ptr;
            14}
            ;
            15
            16
            17void ProcessAdoption(istream &data)
            18{
            19
            20    while (data)                            // 如果還有數(shù)據(jù)
            21    {
            22        auto_ptr<ALA> pa(readALADara(data));
            23        pa->DealProcessAdoption(data);
            24    }

            25    return;
            26}


            這個(gè)版本和原先版本的差異只有二處,
            第一pa是一智能指針的對(duì)象,不是ALA*
            第二不用自己去釋放delete

            然后我看到Effective STL的條款
            8:永不建立auto_ptr的容器
            關(guān)于此可以看的Effective STL的條款8

            因?yàn)閍uto_ptr并不是完美無(wú)缺的,它的確很方便,但也有缺陷,在使用時(shí)要注意避免。首先,不要將auto_ptr對(duì)象作為STL容器的元素。C++標(biāo)準(zhǔn)明確禁止這樣做,否則可能會(huì)碰到不可預(yù)見的結(jié)果

            auto_ptr的另一個(gè)缺陷是將數(shù)組作為auto_ptr的參數(shù): auto_ptr<char>  pstr (new char[12] ); //數(shù)組;為定義
            然后釋放資源的時(shí)候不知道到底是利用delete pstr,還是 delete[] pstr;

            然后收集了關(guān)于auto_ptr的幾種注意事項(xiàng):
            1、auto_ptr不能共享所有權(quán)。
            2、auto_ptr不能指向數(shù)組
            3、auto_ptr不能作為容器的成員。
            4、不能通過(guò)賦值操作來(lái)初始化auto_ptr
            std::auto_ptr<int> p(new int(42));     //OK
            std::auto_ptr<int> p = new int(42);    //ERROR
            這是因?yàn)閍uto_ptr 的構(gòu)造函數(shù)被定義為了explicit
            5、不要把a(bǔ)uto_ptr放入容器

            然后筆者從而推薦的是boost的shared_ptr,然后看完shared_ptr關(guān)于智能指針的介紹與例子。
            5種針對(duì)auto_ptr不足的指針如下:需要詳細(xì)了解可以去查看相當(dāng)文檔,與測(cè)試新代碼。
            scoped_ptr <boost/scoped_ptr.hpp> 簡(jiǎn)單的單一對(duì)象的唯一所有權(quán)。不可拷貝。
            scoped_array <boost/scoped_array.hpp> 簡(jiǎn)單的數(shù)組的唯一所有權(quán)。不可拷貝。
            shared_ptr <boost/shared_ptr.hpp> 在多個(gè)指針間共享的對(duì)象所有權(quán)。
            shared_array <boost/shared_array.hpp> 在多個(gè)指針間共享的數(shù)組所有權(quán)。
            weak_ptr <boost/weak_ptr.hpp> 一個(gè)屬于 shared_ptr 的對(duì)象的無(wú)所有權(quán)的觀察者。
            intrusive_ptr <boost/intrusive_ptr.hpp> 帶有一個(gè)侵入式引用計(jì)數(shù)的對(duì)象的共享所有權(quán)。

            1. shared_ptr是Boost庫(kù)所提供的一個(gè)智能指針的實(shí)現(xiàn),shared_ptr就是為了解決auto_ptr在對(duì)象所有權(quán)上的局限性(auto_ptr是獨(dú)占的),在使用引用計(jì)數(shù)的機(jī)制上提供了可以共享所有權(quán)的智能指針.
            2. shared_ptr比auto_ptr更安全
            3. shared_ptr是可以拷貝和賦值的,拷貝行為也是等價(jià)的,并且可以被比較,這意味這它可被放入標(biāo)準(zhǔn)庫(kù)的一般容器(vector,list)和關(guān)聯(lián)容器中(map)。

            關(guān)于shared_ptr的使用其實(shí)和auto_ptr差不多,只是實(shí)現(xiàn)上有差別,關(guān)于shared_ptr的定義就不貼代碼了,以為內(nèi)開源,可以網(wǎng)上找
            1、shared_ptr<T> p(new Y);


            要了解更多關(guān)于auto_ptr的信息,可以查看more effective c++ 的p158頁(yè)條款28
            要了解shared_ptr 類模板信息,可以查看boost 1.37.0中文文檔,而且支持?jǐn)?shù)組的shared_array 類模板
                

            posted on 2009-03-29 15:50 expter 閱讀(31304) 評(píng)論(5)  編輯 收藏 引用 所屬分類: 其他學(xué)習(xí)筆記算法與數(shù)據(jù)結(jié)構(gòu)

            評(píng)論

            # re: 智能指針(auto_ptr 和 shared_ptr) 2009-11-12 10:17 cxxx

            good..  回復(fù)  更多評(píng)論   

            # re: 智能指針(auto_ptr 和 shared_ptr) 2010-12-22 12:18 +v

            Very good, EFF STL我白看了,博主幫我溫習(xí)了一部分。
              回復(fù)  更多評(píng)論   

            # re: 智能指針(auto_ptr 和 shared_ptr) 2013-07-29 11:28 ght

            謝謝指點(diǎn)  回復(fù)  更多評(píng)論   

            # re: 智能指針(auto_ptr 和 shared_ptr) 2014-01-23 10:39 XX

            寫得不錯(cuò)  回復(fù)  更多評(píng)論   

            # re: 智能指針(auto_ptr 和 shared_ptr)[未登錄](méi) 2014-11-29 20:52 codeMan

            應(yīng)該要重載 -> 和 * 吧  回復(fù)  更多評(píng)論   

            久久精品欧美日韩精品| 久久精品国产亚洲AV不卡| 国产精品久久久亚洲| 免费精品久久久久久中文字幕 | 粉嫩小泬无遮挡久久久久久 | 91精品国产高清久久久久久国产嫩草| 久久久这里有精品中文字幕| 精品久久久久久成人AV| 久久久久亚洲精品日久生情| 久久夜色精品国产www| a级毛片无码兔费真人久久| 欧美噜噜久久久XXX| 久久久久亚洲AV无码专区体验 | 精品久久久久久国产潘金莲 | 欧美精品九九99久久在观看| 性做久久久久久久| 亚洲av日韩精品久久久久久a| 久久婷婷五月综合国产尤物app| 久久婷婷五月综合97色直播| 国产精品99久久久精品无码| 久久一日本道色综合久久| 日本三级久久网| 久久婷婷是五月综合色狠狠| 久久棈精品久久久久久噜噜| 狠狠色婷婷综合天天久久丁香| 要久久爱在线免费观看| 久久精品亚洲精品国产色婷| 精品欧美一区二区三区久久久 | 国产精品成人无码久久久久久 | 欧美精品乱码99久久蜜桃| 狠狠色丁香久久综合婷婷| 久久无码国产专区精品| 国产精品美女久久久免费| 午夜不卡久久精品无码免费| 亚洲精品无码久久不卡| 国产精品gz久久久| 91久久九九无码成人网站| 久久精品国产精品国产精品污| 久久精品国产亚洲AV电影| 狠狠综合久久综合88亚洲| 久久亚洲AV无码精品色午夜|