日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

delete 和 delete [] 的真正区别

發(fā)布時間:2024/4/18 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 delete 和 delete [] 的真正区别 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

c++中對new申請的內(nèi)存的釋放方式有delete和delete[]兩種方式,到底這兩者有什么區(qū)別呢?

1.我們通常從教科書上看到這樣的說明:

delete 釋放new分配的單個對象指針指向的內(nèi)存

delete[] 釋放new分配的對象數(shù)組指針指向的內(nèi)存

那么,按照教科書的理解,我們看下下面的代碼:

int?*a?=?new?int[10];

delete?a;????????//方式1

delete?[]?a;?????//方式2

肯定會有很多人說方式1肯定存在內(nèi)存泄漏,是這樣嗎?

(1). 針對簡單類型 使用new分配后的不管是數(shù)組還是非數(shù)組形式內(nèi)存空間用兩種方式均可 如:

int?*a?=?new?int[10];

delete?a;

delete?[]?a;

此種情況中的釋放效果相同,原因在于:分配簡單類型內(nèi)存時,內(nèi)存大小已經(jīng)確定,系統(tǒng)可以記憶并且進(jìn)行管理,在析構(gòu)時,系統(tǒng)并不會調(diào)用析構(gòu)函數(shù),

它直接通過指針可以獲取實際分配的內(nèi)存空間,哪怕是一個數(shù)組內(nèi)存空間(在分配過程中 系統(tǒng)會記錄分配內(nèi)存的大小等信息,此信息保存在結(jié)構(gòu)體_CrtMemBlockHeader中,

具體情況可參看VC安裝目錄下CRTSRCDBGDEL.cpp)

(2). 針對類Class,兩種方式體現(xiàn)出具體差異

當(dāng)你通過下列方式分配一個類對象數(shù)組:

class?A

???{

???private:

??????char?*m_cBuffer;

??????int?m_nLen;

???public:

??????A(){?m_cBuffer?=?new?char[m_nLen];?}

??????~A()?{?delete?[]?m_cBuffer;?}

???};

???A *a?=?new?A[10];

???delete?a;?????????//僅釋放了a指針指向的全部內(nèi)存空間 但是只調(diào)用了a[0]對象的析構(gòu)函數(shù) 剩下的從a[1]到a[9]這9個用戶自行分配的m_cBuffer對應(yīng)內(nèi)存空間將不能釋放 從而造成內(nèi)存泄漏

???delete?[]?a;??????//調(diào)用使用類對象的析構(gòu)函數(shù)釋放用戶自己分配內(nèi)存空間并且釋放了a指針指向的全部內(nèi)存空間

所以總結(jié)下就是,如果ptr代表一個用new申請的內(nèi)存返回的內(nèi)存空間地址,即所謂的指針,那么:

delete ? ptr ? 代表用來釋放內(nèi)存,且只用來釋放ptr指向的內(nèi)存。?

delete[] ? rg ? 用來釋放rg指向的內(nèi)存,!!還逐一調(diào)用數(shù)組中每個對象的destructor!!

對于像int/char/long/int*/struct等等簡單數(shù)據(jù)類型,由于對象沒有destructor,所以用delete 和delete [] 是一樣的!但是如果是C++對象數(shù)組就不同了!

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

對于 (1),上面提供的程序已經(jīng)證明了 delete[] 和 delete 是等同的。但是對于 (2),情況就發(fā)生了變化。

我們來看下面的例子,通過例子的學(xué)習(xí)了解C++中的delete和delete[]的使用方法

#include <iostream>

using?namespace?std;

/class Babe

class?Babe

{

public:

????Babe()

????{

????????cout?<<?\"Create?a?Babe?to?talk with?me\"?<<?endl;

????}

????~Babe()

????{

????????cout?<<?\"Babe?don\'t?Go?away,listen?to?me\"?<<?endl;

????}

};

//main function

int?main()

{

????Babe*?pbabe?=?new?Babe[3];

????delete?pbabe;

????pbabe?=?new?Babe[3];

????delete?pbabe[];

????return?0;

}

?

結(jié)果是:

Create?a?babe?to?talk with me

Create?a?babe?to?talk with me

Create?a?babe?to?talk with me

Babe?don\'t?go?away,listen?to?me

Create?a?babe?to?talk with me

Create?a?babe?to?talk with me

Create?a?babe?to?talk with me

Babe?don\'t?go?away,listen?to?me

Babe?don\'t?go?away,listen?to?me

Babe?don\'t?go?away,listen?to?me

大家都看到了,只使用delete的時候只出現(xiàn)一個 Babe don’t go away,listen to me,而使用delete[]的時候出現(xiàn)3個 Babe don’t go away,listen to me。不過不管使用delete還是delete[]那三個對象的在內(nèi)存中都被刪除,既存儲位置都標(biāo)記為可寫,但是使用delete的時候只調(diào)用了pbabe[0]的析構(gòu)函數(shù),而使用了delete[]則調(diào)用了3個Babe對象的析構(gòu)函數(shù)。你一定會問,反正不管怎樣都是把存儲空間釋放了,有什么區(qū)別。答:關(guān)鍵在于調(diào)用析構(gòu)函數(shù)上。此程序的類沒有使用操作系統(tǒng)的系統(tǒng)資源(比如:Socket、File、Thread等),所以不會造成明顯惡果。如果你的類使用了操作系統(tǒng)資源,單純把類的對象從內(nèi)存中刪除是不妥當(dāng)?shù)?#xff0c;因為沒有調(diào)用對象的析構(gòu)函數(shù)會導(dǎo)致系統(tǒng)資源不被釋放,如果是Socket則會造成Socket資源不被釋放,最明顯的就是端口號不被釋放,系統(tǒng)最大的端口號是65535(216 _ 1,因為還有0),如果端口號被占用了,你就不能上網(wǎng)了,呵呵。如果File資源不被釋放,你就永遠(yuǎn)不能修改這個文件,甚至不能讀這個文件(除非注銷或重器系統(tǒng))。如果線程不被釋放,這它總在后臺運(yùn)行,浪費(fèi)內(nèi)存和CPU資源。這些資源的釋放必須依靠這些類的析構(gòu)函數(shù)。所以,在用這些類生成對象數(shù)組的時候,用delete[]來釋放它們才是王道。而用delete來釋放也許不會出問題,也許后果很嚴(yán)重,具體要看類的代碼了.

總結(jié)

以上是生活随笔為你收集整理的delete 和 delete [] 的真正区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。