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操作符進行記憶體申請,該記憶體即為自由儲存區。而堆是作業系統中的術語,是作業系統所維護的一塊特殊記憶體,用於程式的記憶體...