• <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>

            清風竹林

            ぷ雪飄絳梅映殘紅
               ぷ花舞霜飛映蒼松
                 ----- Do more,suffer less

            delete this--對象請求自殺

            delete this--對象請求自殺

            版本:0.1

            最后修改:2009-08-18

            撰寫:李現民


                 第一次見delete this的時候,沒覺得這是一項會有什么特殊作用的技術,因此也就沒有特別關注。

                 昨日在sourcemaking.com上看state模式之c++實現的時候,看到它在狀態轉換的時候使用了delete this,感覺似乎還不錯。

                 作為一種“禁術”,使用的時候必須要相當小心才行,《C++ FAQ》里提到所謂“小心”至少包括以下幾個方面:

            1. this對象是必須是用 new操作符分配的(而不是用new[],也不是用placement new,也不是局部對象,也不是global對象);

            2. delete this后,不能訪問該對象任何的成員變量及虛函數(delete this回收的是數據,這包括對象的數據成員以及vtable,不包括函數代碼);

            3. delete this后,不能再訪問this指針。換句話說,你不能去檢查它、將它和其他指針比較、和 NULL比較、打印它、轉換它,以及其它的任何事情;


                 個人認為保證以上禁忌列表基本手段可以包括:

            1. 析構函數私有化(如果有子類,則protected化,保證子類能夠正確繼承)--以保證對象必須使用new在堆上分配內存;

            2. 提供(可以在僅僅在基類中)Destroy(void)函數,里面僅有一句delete this--以保證第三方能夠將分配的內存回收;


                 下一次使用state pattern的時候,我想可以嘗試一下。

            posted on 2009-08-18 11:07 李現民 閱讀(5976) 評論(0)  編輯 收藏 引用 所屬分類: 語法試煉

            A级毛片无码久久精品免费| 91精品国产高清久久久久久国产嫩草 | 性做久久久久久久久| 午夜福利91久久福利| 91精品国产综合久久婷婷| 一级做a爰片久久毛片人呢| 伊人久久大香线蕉AV一区二区| 久久精品国产亚洲AV无码娇色 | 人妻精品久久无码区| 国产精品免费福利久久| 久久一区二区三区免费| 国产V综合V亚洲欧美久久 | 亚洲狠狠婷婷综合久久蜜芽| 久久精品一区二区三区不卡| 久久精品国产亚洲一区二区三区 | 日本久久中文字幕| 免费精品99久久国产综合精品| 久久只这里是精品66| 一级做a爰片久久毛片人呢| 色欲av伊人久久大香线蕉影院| 欧美久久久久久精选9999| 2021少妇久久久久久久久久| 久久精品亚洲AV久久久无码 | 婷婷伊人久久大香线蕉AV | 日韩电影久久久被窝网| 久久综合九色综合97_久久久| 午夜不卡久久精品无码免费| 无码乱码观看精品久久| 久久99精品久久久久久野外| 亚洲国产精久久久久久久| 久久亚洲欧美日本精品| 国产精品久久自在自线观看| 欧洲人妻丰满av无码久久不卡| 影音先锋女人AV鲁色资源网久久| 久久久久国色AV免费观看| 国产亚洲成人久久| 办公室久久精品| 久久综合久久鬼色| 色偷偷88欧美精品久久久| 亚洲国产成人久久一区WWW| 久久99热这里只有精品66|