• <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 李現民 閱讀(5992) 評論(0)  編輯 收藏 引用 所屬分類: 語法試煉

            国产精品久久久久天天影视| 色欲综合久久躁天天躁蜜桃| 无码超乳爆乳中文字幕久久| 久久免费国产精品一区二区| 久久亚洲天堂| 97久久久久人妻精品专区| 伊人精品久久久久7777| 国产香蕉97碰碰久久人人| 一级做a爰片久久毛片人呢| 久久精品日日躁夜夜躁欧美| 三级韩国一区久久二区综合| 国产美女久久久| 国产成人精品久久| 久久无码人妻精品一区二区三区| 国产精品久久久久乳精品爆| segui久久国产精品| 久久久久久亚洲精品无码| 久久综合给合综合久久| 亚洲乱码日产精品a级毛片久久 | 久久99精品国产麻豆蜜芽| 久久精品国产亚洲av瑜伽| 伊人久久大香线蕉AV一区二区| 久久亚洲熟女cc98cm| 国内精品人妻无码久久久影院| 成人妇女免费播放久久久| 国产午夜精品久久久久九九| 亚洲欧洲久久久精品| 久久久久亚洲AV成人片| 亚洲精品无码久久久久AV麻豆| 国内精品久久久久久99蜜桃 | 久久伊人中文无码| 国产精品久久久久影院色| 热久久视久久精品18| 亚洲伊人久久成综合人影院| 亚洲一本综合久久| jizzjizz国产精品久久| 性欧美大战久久久久久久久| 性欧美大战久久久久久久| 狠狠色伊人久久精品综合网 | 欧美综合天天夜夜久久| 精品午夜久久福利大片|