C++中delete和delete[]的區(qū)別說明
C++告訴我們在回收用 new 分配的單個(gè)對象的內(nèi)存空間的時(shí)候用 delete,回收用 new[] 分配的一組對象的內(nèi)存空間的時(shí)候用 delete[]。 關(guān)于 new[] 和 delete[],其中又分為兩種情況:(1) 為基本數(shù)據(jù)類型分配和回收空間;(2) 為自定義類型分配和回收空間。
請看下面的程序。
#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 在回收空間的過程中,只有 p1[0] 這個(gè)對象調(diào)用了析構(gòu)函數(shù),其它對象如 p1[1]、p1[2] 等都沒有調(diào)用自身的析構(gòu)函數(shù),這就是問題的癥結(jié)所在。如果用 delete[],則在回收空間之前所有對象都會(huì)首先調(diào)用自己的析構(gòu)函數(shù)。 基本類型的對象沒有析構(gòu)函數(shù),所以回收基本類型組成的數(shù)組空間用 delete 和 delete[] 都是應(yīng)該可以的;但是對于類對象數(shù)組,只能用 delete[]。對于 new 的單個(gè)對象,只能用 delete 不能用 delete[] 回收空間。 所以一個(gè)簡單的使用原則就是:new 和 delete、new[] 和 delete[] 對應(yīng)使用。
我的理解,當(dāng)用delete來釋放用new int[]申請的內(nèi)存空間時(shí),由于其為基本數(shù)據(jù)類型沒有析構(gòu)函數(shù),所以使用delete與delete []相同,兩者都會(huì)釋放申請的內(nèi)存空間,若是自定義的數(shù)據(jù)類型,有析構(gòu)函數(shù)時(shí),用new []申請的空間,必須要用delete []來釋放,因?yàn)橐猟elete []時(shí)會(huì)逐一調(diào)用對象數(shù)組的析構(gòu)函數(shù),然后釋放空間,如果用delete,則只會(huì)調(diào)用第一個(gè)對象的析構(gòu)函數(shù),后面對象的析構(gòu)函數(shù)沒有被調(diào)用,那么其空間是否釋放了呢??
相關(guān)文章
C語言函數(shù)調(diào)用基礎(chǔ)應(yīng)用詳解
函數(shù)就是一段封裝好的,可以重復(fù)使用的代碼,它使得我們的程序更加模塊化,不需要編寫大量重復(fù)的代碼。這篇文章主要介紹了c語言是如何處理函數(shù)調(diào)用的?需要的朋友可以參考下2023-02-02Qt創(chuàng)建SQlite數(shù)據(jù)庫的示例代碼
本文主要介紹了Qt創(chuàng)建SQlite數(shù)據(jù)庫的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05C語言?詳解如何刪除有序數(shù)組中的重復(fù)項(xiàng)
數(shù)組不擅長插入(添加)和刪除元素。數(shù)組的優(yōu)點(diǎn)在于它是連續(xù)的,所以查找數(shù)據(jù)速度很快。但這也是它的一個(gè)缺點(diǎn)。正因?yàn)樗沁B續(xù)的,所以當(dāng)插入一個(gè)元素時(shí),插入點(diǎn)后所有的元素全部都要向后移;而刪除一個(gè)元素時(shí),刪除點(diǎn)后所有的元素全部都要向前移2022-03-03Matlab實(shí)現(xiàn)繪制雷達(dá)圖(蜘蛛圖)
這篇文章主要為大家詳細(xì)介紹了如何利用Matlab實(shí)現(xiàn)雷達(dá)圖(蜘蛛圖)的繪制,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Matlab有一定幫助,需要的可以參考一下2022-09-09輸出1000以內(nèi)的素?cái)?shù)的算法(實(shí)例代碼)
本篇文章是對輸出1000以內(nèi)的素?cái)?shù)的算法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05