1、new 是c++中的操作符,malloc是c 中的一個函數
2、new 不止是分配記憶體,而且會調用類的建構函式,同理delete會調用類的解構函式,而malloc則只分配記憶體,不會進行初始化類成員的工作,同樣free也不會調用解構函式
3、記憶體流失對於malloc或者new都可以檢查出來的,區別在於new可以指明是那個檔案的那一行,而malloc沒有這些資訊。
4、new 和 malloc效率比較
new 有三個字母, malloc有六個字母
new可以認為是malloc加建構函式的執行。
new出來的指標是直接帶類型資訊的。
而malloc返回的都是void指標。
1.malloc與free是C++/C語言的標準庫函數,new/delete是C++的運算子。它們都可用於申請動態記憶體和釋放記憶體。2,對於
非內部資料類型的對象而言,光用maloc/free無法滿足動態對象的要求。對象在建立的同時要自動執行建構函式,對象在消亡之前要自動執行解構函式。
由於malloc/free是庫函數而不是運算子,不在編譯器控制許可權之內,不能夠把執行建構函式和解構函式的任務強加於malloc/free。3,因
此C++語言需要一個能完成動態記憶體分配和初始化工作的運算子new,以一個能完成清理與釋放記憶體工作的運算子delete。注意new/delete不
是庫函數。4,C++程式經常要調用C函數,而C程式只能用malloc/free管理動態記憶體new
是個操作符,和什麼"+","-","="...有一樣的地位.malloc是個分配記憶體的函數,供你調用的.new是保留字,不需要標頭檔支
持.malloc需要標頭檔庫函數支援.new
建立的是一個對象,malloc分配的是一塊記憶體.new建立的對象你可以把它當成一個普通的對象,用成員函數訪問,不要直接存取它的地址空間
malloc分配的是一塊記憶體地區,就用指標訪問好了,而且還可以在裡面移動指標.
malloc與free是C++/C語言的標準庫函數,new/delete是C++的運算子。它們都可用於申請動態記憶體和釋放記憶體。
對
於非內部資料類型的對象而言,光用maloc/free無法滿足動態對象的要求。對象在建立的同時要自動執行建構函式,對象在消亡之前要自動執行析構函
數。由於malloc/free是庫函數而不是運算子,不在編譯器控制許可權之內,不能夠把執行建構函式和解構函式的任務強加於malloc/free。
因此C++語言需要一個能完成動態記憶體分配和初始化工作的運算子new,以及一個能完成清理與釋放記憶體工作的運算子delete。注意new/delete不是庫函數。
我們先看一看malloc/free和new/delete如何?對象的動態記憶體管理,見下面樣本。
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;
//
清除並且釋放記憶體
}
類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也一樣。