轉(zhuǎn)自:http://www.cnblogs.com/charley_yang/archive/2010/12/08/1899982.html
一直對(duì)C++中的delete和delete[]的區(qū)別不甚了解,今天遇到了,上網(wǎng)查了一下,得出了結(jié)論。做個(gè)備份,以免丟失。
????
C++告訴我們?cè)诨厥沼?new 分配的單個(gè)對(duì)象的內(nèi)存空間的時(shí)候用 delete,回收用 new[] 分配的一組對(duì)象的內(nèi)存空間的時(shí)候用 delete[]。?
關(guān)于 new[] 和 delete[],其中又分為兩種情況:(1) 為基本數(shù)據(jù)類型分配和回收空間;(2) 為自定義類型分配和回收空間。
請(qǐng)看下面的程序。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
#include <iostream>;
using
?
namespace
?
std;
?
class
?
T {
public
:
??
T() { cout <<
"constructor"
?
<< endl; }
??
~T() { cout <<
"destructor"
?
<< endl; }
};
?
int
?
main()
{
??
const
?
int
?
NUM = 3;
?
??
T* p1 =
new
?
T[NUM];
??
cout << hex << p1 << endl;
??
//? delete[] p1;
??
delete
?
p1;
?
??
T* p2 =
new
?
T[NUM];
??
cout << p2 << endl;
??
delete
[] p2;
}
|
?
大家可以自己運(yùn)行這個(gè)程序,看一看 delete p1 和 delete[] p1 的不同結(jié)果,我就不在這里貼運(yùn)行結(jié)果了。
????
從運(yùn)行結(jié)果中我們可以看出,delete p1 在回收空間的過(guò)程中,只有 p1[0] 這個(gè)對(duì)象調(diào)用了析構(gòu)函數(shù),其它對(duì)象如 p1[1]、p1[2] 等都沒(méi)有調(diào)用自身的析構(gòu)函數(shù),這就是問(wèn)題的癥結(jié)所在。如果用 delete[],則在回收空間之前所有對(duì)象都會(huì)首先調(diào)用自己的析構(gòu)函數(shù)。?
????
基本類型的對(duì)象沒(méi)有析構(gòu)函數(shù),所以回收基本類型組成的數(shù)組空間用 delete 和 delete[] 都是應(yīng)該可以的;但是對(duì)于類對(duì)象數(shù)組,只能用 delete[]。對(duì)于 new 的單個(gè)對(duì)象,只能用 delete 不能用 delete[] 回收空間。?
????
所以一個(gè)簡(jiǎn)單的使用原則就是:new 和 delete、new[] 和 delete[] 對(duì)應(yīng)使用。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
