C++中delete和delete[]的區別說明

來源:互聯網
上載者:User

C++告訴我們在回收用 new 分配的單個對象的記憶體空間的時候用 delete,回收用 new[] 分配的一組對象的記憶體空間的時候用 delete[]。 關於 new[] 和 delete[],其中又分為兩種情況:(1) 為基礎資料型別 (Elementary Data Type)分配和回收空間;(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;
}

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

從運行結果中我們可以看出,delete p1 在回收空間的過程中,只有 p1[0] 這個對象調用了解構函式,其它對象如 p1[1]、p1[2] 等都沒有調用自身的解構函式,這就是問題的癥結所在。如果用 delete[],則在回收空間之前所有對象都會首先調用自己的解構函式。 基本類型的對象沒有解構函式,所以回收基本類型組成的數組空間用 delete 和 delete[] 都是應該可以的;但是對於類對象數組,只能用 delete[]。對於 new 的單個對象,只能用 delete 不能用 delete[] 回收空間。 所以一個簡單的使用原則就是:new 和 delete、new[] 和 delete[] 對應使用。

我的理解,當用delete來釋放用new int[]申請的記憶體空間時,由於其為基礎資料型別 (Elementary Data Type)沒有解構函式,所以使用delete與delete []相同,兩者都會釋放申請的記憶體空間,若是自訂的資料類型,有解構函式時,用new []申請的空間,必須要用delete []來釋放,因為要delete []時會逐一調用對象數組的解構函式,然後釋放空間,如果用delete,則只會調用第一個對象的解構函式,後面對象的解構函式沒有被調用,那麼其空間是否釋放了呢??

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.