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

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            delete與delete[]的區別

            new分配的一個數組空間,比如說 int *array=new int[50],當用delete釋放這個空間時,用語句delete []arraydelete array是否等價!

            C++告訴我們在回收用 new 分配的單個對象的內存空間的時候用 delete,回收用 new[] 分配的一組對象的內存空間的時候用 delete[]。

            關于 new[] delete[],其中又分為兩種情況:(1) 為基本數據類型分配和回收空間;(2) 為自定義類型分配和回收空間。

            對于 (1),上面提供的程序a可以證明了 delete[] delete 是等同的。
            程序a
            #include <stdio.h>
            #define BUFF_SIZE 10240
            int main(int argc, char *argv[])
            {
            printf("Hello, world\n";
            char* p = NULL;
            while(1)
            {
            p = new TTT[BUFF_SIZE];
            printf("0x%08XH\n",p);
            Sleep(5000);
            delete p; //
            或者delete [] p;
            p = NULL;
            }
            return 0;
            }

            但是對于 (2),情況就發生了變化。請看下面的程序。
            #include <stdio.h>
            #define BUFF_SIZE 10240

            class TTT
            {
            public:
            TTT()
            {
            //aa = new char[1024];
            };
            ~TTT()
            {
            //delete [] aa;
            //printf("TTT destructor()\n";
            };
            private:
            int a;
            char* aa;
            int inta[1024];
            };

            int main(int argc, char *argv[])
            {
            printf("Hello, world\n";
            TTT* p = NULL;
            while(1)
            {
            p = new TTT[BUFF_SIZE];
            printf("0x%08XH\n",p);
            delete p; //delete [] p;
            p = NULL;
            }
            return 0;
            }

            大家可以自己運行這個程序,看一看 delete p1 delete[] p1 的不同結果,我就不在這里貼運行結果了。

            從運行結果中我們可以看出,delete p 在回收空間的過程中,只有 p[0] 這個對象調用了析構函數,其它對象如 p[1]p[2] 等都沒有調用自身的析構函數,在析構函數中的內存釋放操作將不會被執行(引發內存泄漏),已使用內存不斷增加,這就是問題的癥結所在。如果用 delete[],則在回收空間之前所有對象都會首先調用自己的析構函數,已使用內存不會不斷增加。

            基本類型的對象沒有析構函數,所以回收基本類型組成的數組空間用 delete delete[] 都是應該可以的;但是對于類對象數組,只能用 delete[]。對于 new 的單個對象,只能用 delete 不能用 delete[] 回收空間。
            參考資料:http://dev.csdn.net/develop/article/38/38316.shtm

            作者后續相關文章:

            昨天寫了一篇關于deletedelete[]的文章,有位仁兄指出我的結論是錯誤的,那樣的結果只會在特定的編譯器程序。為了不會誤導大家,文章意見刪除。回家后仔細看了《Effective C++》,是我看書太不仔細了,雖然忘了那位仁兄是誰了,在這里還是謝謝你。現將《Effective C++》中正確的觀點、結論摘錄如下:

            1.              當你使用new時,有兩件事會發生。第一,內存被配置(透過函數operator new)。第二,會有一個(或以上)的constructors針對此內存被調用。當你使用delete,也有兩件事發生:一個(或以上)的destructors會針對此內存被調用,然后內存被釋放(透過函數operator delete)。

            2.              如果你使用delete是未加括號,delete便假設刪除對象是單一對象。否則便假設刪除對象是個數組。

            3.              string *stringPtr1 = new string;

            string *stringPtr2 = new string[100];

            ……

            delete stringPtr1;

            delete [] stringPtr2;

            如果你對著stringPtr1使用“[]”形式,其結果未定義。如果你對著stringPtr2沒有使用“[]”形式,其結果亦未定義。猶有進者,這對內建型別如int者亦未定義,即使這類型別并沒有destructors。

            4.              因此,游戲規則很簡單,如果你在調用new時使用了[],則你在調用delete時也使用[],如果你在調用new的時候沒有[],那么你也不應該在調用時使用[]。

            posted on 2011-08-19 16:38 肥仔 閱讀(870) 評論(0)  編輯 收藏 引用 所屬分類: C++ 基礎

            久久99精品国产麻豆婷婷| 亚洲国产成人久久综合一区77| 国产婷婷成人久久Av免费高清| 国内精品伊人久久久久| 久久久免费观成人影院| 久久精品国产亚洲av麻豆小说 | 99热热久久这里只有精品68| 久久国产精品二国产精品| 亚洲精品乱码久久久久久蜜桃不卡| 久久国产精品久久精品国产| 国产精品久久久久免费a∨| 26uuu久久五月天| 久久久国产精品亚洲一区| 亚洲国产成人久久综合一区77| 久久发布国产伦子伦精品| 久久综合亚洲鲁鲁五月天| 久久99精品九九九久久婷婷| 久久久国产精品亚洲一区| 尹人香蕉久久99天天拍| 国产精品成人久久久久三级午夜电影| 久久精品日日躁夜夜躁欧美| 久久天天躁狠狠躁夜夜av浪潮 | 狠狠色丁香婷婷久久综合不卡| 久久精品国产影库免费看| 久久天天婷婷五月俺也去| 精品乱码久久久久久久| 一本久久a久久精品vr综合| 久久精品桃花综合| 久久高潮一级毛片免费| 91精品婷婷国产综合久久| 国产精品久久久久久久久免费| 亚洲国产精品18久久久久久| 亚洲综合久久久| 国产精品99久久久久久宅男小说| 久久亚洲天堂| 久久婷婷人人澡人人| 久久高潮一级毛片免费| 久久亚洲高清综合| 亚州日韩精品专区久久久| 久久综合亚洲色HEZYO社区| 久久人人爽人人爽人人片AV东京热 |