欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++中delete和delete[]的區(qū)別

 更新時(shí)間:2016年03月21日 10:36:06   投稿:hebedich  
這篇文章主要介紹了C++中delete和delete[]的區(qū)別的相關(guān)資料,需要的朋友可以參考下

一直對(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)看下面的程序。

#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)使用。

  我的理解,當(dāng)用delete來(lái)釋放用new int[]申請(qǐng)的內(nèi)存空間時(shí),由于其為基本數(shù)據(jù)類型沒(méi)有析構(gòu)函數(shù),所以使用delete與delete []相同,兩者都會(huì)釋放申請(qǐng)的內(nèi)存空間,若是自定義的數(shù)據(jù)類型,有析構(gòu)函數(shù)時(shí),用new []申請(qǐng)的空間,必須要用delete []來(lái)釋放,因?yàn)橐猟elete []時(shí)會(huì)逐一調(diào)用對(duì)象數(shù)組的析構(gòu)函數(shù),然后釋放空間,如果用delete,則只會(huì)調(diào)用第一個(gè)對(duì)象的析構(gòu)函數(shù),后面對(duì)象的析構(gòu)函數(shù)沒(méi)有被調(diào)用,那么其空間是否釋放了呢??

相關(guān)文章

  • C++調(diào)用EasyX庫(kù)實(shí)現(xiàn)嫦娥奔月小游戲

    C++調(diào)用EasyX庫(kù)實(shí)現(xiàn)嫦娥奔月小游戲

    這篇文章主要為大家詳細(xì)介紹了C++如何調(diào)用EasyX庫(kù)編寫(xiě)一個(gè)簡(jiǎn)單的嫦娥奔月小游戲,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以參考一下
    2023-09-09
  • C++指針數(shù)組、數(shù)組指針、數(shù)組名及二維數(shù)組技巧匯總

    C++指針數(shù)組、數(shù)組指針、數(shù)組名及二維數(shù)組技巧匯總

    這篇文章主要介紹了C++指針數(shù)組、數(shù)組指針、數(shù)組名及二維數(shù)組技巧匯總,對(duì)于深入理解C++數(shù)組與指針來(lái)說(shuō)非常重要,需要的朋友可以參考下
    2014-08-08
  • C語(yǔ)言楊氏矩陣查找算法實(shí)例講解

    C語(yǔ)言楊氏矩陣查找算法實(shí)例講解

    楊氏矩陣是一個(gè)數(shù)字矩陣,矩陣的每一行從左到右一次遞增,矩陣從上到下遞增,在這樣的矩陣中查找一個(gè)數(shù)字是否存在。時(shí)間復(fù)雜度小于O(N),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-09-09
  • 嵌入式QT移植的實(shí)現(xiàn)

    嵌入式QT移植的實(shí)現(xiàn)

    本文主要介紹了嵌入式QT移植的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • C++中調(diào)用復(fù)制(拷貝)函數(shù)的三種情況總結(jié)

    C++中調(diào)用復(fù)制(拷貝)函數(shù)的三種情況總結(jié)

    這篇文章主要介紹了C++中調(diào)用復(fù)制(拷貝)函數(shù)的三種情況總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 通俗易懂的C++前綴和與差分算法圖文示例詳解

    通俗易懂的C++前綴和與差分算法圖文示例詳解

    這篇文章主要為大家非常通俗易懂的講解了C++前綴和與差分算法的圖文分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2021-11-11
  • C++通過(guò)CryptoPP計(jì)算Hash值的過(guò)程詳解

    C++通過(guò)CryptoPP計(jì)算Hash值的過(guò)程詳解

    Crypto++ (CryptoPP) 是一個(gè)用于密碼學(xué)和加密的C++庫(kù),它是一個(gè)開(kāi)源項(xiàng)目,提供了大量的密碼學(xué)算法和功能,本文小編給大家介紹了C++通過(guò)CryptoPP計(jì)算Hash值的過(guò)程,文中通過(guò)代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • C++求Fib數(shù)列

    C++求Fib數(shù)列

    本文給大家匯總介紹了幾種C++求Fib數(shù)列的方法,有需要的小伙伴們可以來(lái)參考下
    2016-02-02
  • VS編譯出現(xiàn)MSB3073命令的解決方案

    VS編譯出現(xiàn)MSB3073命令的解決方案

    =error MSB3073是Visual Studio編譯器報(bào)出的錯(cuò)誤,本文主要介紹了VS編譯出現(xiàn)MSB3073命令的解決方案,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之線索二叉樹(shù)及其遍歷

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之線索二叉樹(shù)及其遍歷

    這篇文章主要介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之線索二叉樹(shù)及其遍歷的相關(guān)資料,為了加快查找節(jié)點(diǎn)的前驅(qū)和后繼。對(duì)二叉樹(shù)的線索化就是對(duì)二叉樹(shù)進(jìn)行一次遍歷,在遍歷的過(guò)程中檢測(cè)節(jié)點(diǎn)的左右指針是否為空,如果是空,則將他們改為指向前驅(qū)和后繼節(jié)點(diǎn)的線索,需要的朋友可以參考下
    2017-08-08

最新評(píng)論