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

            国产精品久久久久jk制服| 色88久久久久高潮综合影院| 青青草原综合久久| 久久久精品日本一区二区三区| 久久精品无码一区二区app| 日产精品久久久久久久| MM131亚洲国产美女久久| 久久午夜无码鲁丝片午夜精品| 色婷婷综合久久久久中文| 国内精品久久久久久久涩爱| 狠狠色丁香婷婷久久综合五月| 久久福利青草精品资源站| 蜜桃麻豆www久久国产精品| 奇米综合四色77777久久| 久久综合九色综合欧美就去吻| 久久精品蜜芽亚洲国产AV| 久久久久香蕉视频| 91麻豆精品国产91久久久久久| 日韩AV毛片精品久久久| 久久久久四虎国产精品| 久久亚洲私人国产精品vA| 久久久久99精品成人片| 91久久九九无码成人网站| 久久久老熟女一区二区三区| 伊人久久大香线蕉综合网站| 国产高潮久久免费观看| 国产精品久久亚洲不卡动漫| 久久婷婷五月综合成人D啪 | 久久水蜜桃亚洲av无码精品麻豆| 伊人色综合久久天天| 青青草国产精品久久久久| 久久国产乱子伦免费精品| 亚洲精品无码久久久影院相关影片 | 亚洲va国产va天堂va久久| 久久99精品久久只有精品| 亚洲乱码中文字幕久久孕妇黑人 | 97r久久精品国产99国产精| 色婷婷综合久久久久中文| 久久综合香蕉国产蜜臀AV| 久久国产精品77777| 日本福利片国产午夜久久|