malloc/free 和 new /delete 的區別 (轉)

amyz發表於2007-11-25
malloc/free 和 new /delete 的區別 (轉)[@more@]

有了malloc/free為什麼還要new/delete ?

  malloc與free是C++/C語言的標準庫,new/delete是C++的運算子。它們都可用於申請動態和釋放記憶體。

對於非內部資料型別的而言,光用maloc/free無法滿足動態物件的要求。物件在建立的同時要自動建構函式,物件在消亡之前要自動執行解構函式。由於malloc/free是庫函式而不是運算子,不在控制之內,不能夠把執行建構函式和解構函式的任務強加於malloc/free。

  因此C++語言需要一個能完成動態記憶體分配和初始化工作的運算子new,以及一個能完成清理與釋放記憶體工作的運算子delete。注意new/delete不是庫函式。

我們先看一看malloc/free和new/delete如何實現物件的動態記憶體管理,見示例7-8。

 :namespace prefix = o ns = "urn:schemas--com::office" />

class Obj

{

public :

  Obj(void){ cout << “Initialization” << endl; }

~Obj(void){ cout << “Destroy” << endl; }

void  Initialize(void){ cout << “Initialization” << endl; }

void  Destroy(void){ cout << “Destroy” << endl; }

};

void UseMallocFree(void)

{

  Obj  *a = (obj *)malloc(sizeof(obj));  // 申請動態記憶體

  a->Initialize();  // 初始化

  //…

  a->Destroy();  // 清除工作

  free(a);  // 釋放記憶體

}

void UseNewDelete(void)

{

  Obj  *a = new Obj;  // 申請動態記憶體並且初始化

  //…

  delete a;  // 清除並且釋放記憶體

}

示例7-8 用malloc/free和new/delete如何實現物件的動態記憶體管理

 

類Obj的函式Initialize模擬了建構函式的功能,函式Destroy模擬了解構函式的功能。函式UseMallocFree中,由於malloc/free不能執行建構函式與解構函式,必須成員函式Initialize和Destroy來完成初始化與清除工作。函式UseNewDelete則簡單得多。

所以我們不要企圖用malloc/free來完成動態物件的記憶體管理,應該用new/delete。由於內部資料型別的“物件”沒有構造與析構的過程,對它們而言malloc/free和new/delete是等價的。

  既然new/delete的功能完全覆蓋了malloc/free,為什麼C++不把malloc/free淘汰出局呢?這是因為C++經常要呼叫C函式,而C程式只能用malloc/free管理動態記憶體。

如果用free釋放“new建立的動態物件”,那麼該物件因無法執行解構函式而可能導致程式出錯。如果用delete釋放“malloc申請的動態記憶體”,理論上講程式不會出錯,但是該程式的可讀性很差。所以new/delete必須配對使用,malloc/free也一樣。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752019/viewspace-984520/,如需轉載,請註明出處,否則將追究法律責任。

相關文章