new和malloc的總結

2021-07-05 17:13:52 字數 4117 閱讀 3558

malloc與free的總結

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管理動態記憶體。 

5.new可以認為是malloc加建構函式的執行。new出來的指標是直接帶型別資訊的。而malloc返回的都是void*指標。所以一般要加上型別轉換,轉換為實際型別才可用。new delete在實現上其實呼叫了malloc,free函式

6.new建立的物件你可以把它當成乙個普通的物件,用成員函式訪問,不要直接訪問它的位址空間;malloc分配的是一塊記憶體區域,就用指標訪問好了,而且還可以在裡面移動指標.

7.new 建立的是乙個物件;alloc分配的是一塊記憶體.

8.相同點:都可用於申請動態記憶體和釋放記憶體

不同點: 

(1)操作物件有所不同。 

malloc與free是c++/c 語言的標準庫函式,new/delete 是c++的運算子。對於非內部資料類的物件而言,光用maloc/free 無法滿足動態物件的要求。物件在建立的同時要自動執行建構函式, 物件消亡之前要自動執行析構函式。由於malloc/free 是庫函式而不是運算子,不在編譯器控制許可權之內,不能夠把執行建構函式和析構函式的任務強加malloc/free。

(2)在用法上也有所不同。 

函式malloc 的原型如下: 

void * malloc(size_t size); 

用malloc 申請一塊長度為length 的整數型別的記憶體,程式如下: 

int *p = (int *) malloc(sizeof(int) * length); 

我們應當把注意力集中在兩個要素上:「型別轉換」和「sizeof」。 

malloc 返回值的型別是void *,所以在呼叫malloc 時要顯式地進行型別轉換,將void * 轉換成所需要的指標型別。 

malloc 函式本身並不識別要申請的記憶體是什麼型別,它只關心記憶體的總位元組數。

9.函式free 的原型如下: 

void free( void * memblock ); 

為什麼free 函式不象malloc 函式那樣複雜呢?這是因為指標p 的型別以及它所指的記憶體的容量事先都是知道的,語句free(p)能正確地釋放記憶體。如果p 是null 指標,那麼free對p 無論操作多少次都不會出問題。如果p 不是null 指標,那麼free 對p連續操作兩次就會導致程式執行錯誤。

10.new/delete 的使用要點 :

運算子new 使用起來要比函式malloc 簡單得多,例如: 

int *p1 = (int *)malloc(sizeof(int) * length); 

int *p2 = new int[length]; 

這是因為new 內建了sizeof、型別轉換和型別安全檢查功能。對於非內部資料型別的物件而言,new 在建立動態物件的同時完成了初始化工作。如果物件有多個建構函式,那麼new 的語句也可以有多種形式。

11.如果用new 建立物件陣列,那麼只能使用物件的無引數建構函式。例如 

obj *objects = new obj[100]; // 建立100 個動態物件 

不能寫成 

obj *objects = new obj[100](1);// 建立100 個動態物件的同時賦初值1 

在用delete 釋放物件陣列時,留意不要丟了符號『』。例如 

delete objects; // 正確的用法 

delete objects; // 錯誤的用法 

後者相當於delete objects[0],漏掉了另外99 個物件。

12.(1) new自動計算需要分配的空間,而malloc需要手工計算位元組數 

(2)  new是型別安全的,而malloc不是,比如: 

int* p = new float[2]; // 編譯時指出錯誤 

int* p = malloc(2*sizeof(float)); // 編譯時無法指出錯誤 

new operator 由兩步構成,分別是 operator new 和 construct 

(3)  operator new對應於malloc,但operator new可以過載,可以自定義記憶體分配策略,甚至不做記憶體分配,甚至分配到非記憶體裝置上。而malloc無能為力 

(4)  new將呼叫constructor,而malloc不能;delete將呼叫destructor,而free不能。 

(5)  malloc/free要庫檔案支援,new/delete則不要。

13.new和malloc的區別

(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指標。

一:new delete 是運算子,malloc,free是函式

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

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

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

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

class obj

~obj(void)

void      initialize(void)

void      destroy(void)

};void usemallocfree(void)

void usenewdelete(void)

示例用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也一樣。

二:new delete在實現上其實呼叫了malloc,free函式。

三:new operator除了分配記憶體,還要呼叫建構函式。malloc函式只是負責分配記憶體

(完)

new 和malloc 的區別總結

new 和malloc 的區別 1.申請的記憶體所在位置 new操作符從自由儲存區 free store 上為物件動態分配記憶體空間,而malloc函式從堆上動態分配記憶體。自由儲存區是c 基於new操作符的乙個抽象概念,凡是通過new操作符進行記憶體申請,該記憶體即為自由儲存區。而堆是作業系統中的...

new和malloc的區別詳細總結

malloc是c中的函式,需要宣告特定的標頭檔案。而new是c 中的關鍵字 操作符 它本身不是函式,所以不依賴於標頭檔案,c 譯器就可以把new編譯成目標 1 申請記憶體所在位置不同 new操作符從自由儲存區分配記憶體空間,而malloc函式從堆上分配記憶體,自由儲存區不同於堆,但是都需要手動釋放,...

malloc函式 new和malloc的區別

1 申請的記憶體所在位置 new操作符從自由儲存區上為物件動態分配記憶體空間,而malloc函式從堆上動態分配記憶體。自由儲存區是c 基於new操作符的乙個抽象概念,凡是通過new操作符進行記憶體申請,該記憶體即為自由儲存區。而堆是作業系統中的術語,是作業系統所維護的一塊特殊記憶體,用於程式的記憶體...