new 和malloc 的區別總結

2021-09-22 22:39:48 字數 2137 閱讀 8879

new 和malloc 的區別

1. 申請的記憶體所在位置

new操作符從自由儲存區(free store)上為物件動態分配記憶體空間,而malloc函式從上動態分配記憶體。自由儲存區是c++基於new操作符的乙個抽象概念,凡是通過new操作符進行記憶體申請,該記憶體即為自由儲存區。而堆是作業系統中的術語,是作業系統所維護的一塊特殊記憶體,用於程式的記憶體動態分配,c語言使用malloc從堆上分配記憶體,使用free釋放已分配的對應記憶體。

2.返回型別安全性

new返回的是物件型別的指標,符合型別安全性的操作符。

而malloc記憶體分配成功則是返回void * ,需要通過強制型別轉換將void*指標轉換成我們需要的型別。

型別安全很大程度上可以等價於記憶體安全,型別安全的**不會試圖修改自己沒被授權的記憶體區域。關於c++的型別安全性可說的又有很多了。

3.記憶體分配失敗時的返回值

new記憶體分配失敗時,會丟擲bac_alloc異常,它不會返回null;malloc分配記憶體失敗時返回null。

4.是否需要指定記憶體大小

使用new操作符申請記憶體分配時無須指定記憶體塊的大小,編譯器會根據型別資訊自行計算,而malloc則需要顯式地指出所需記憶體的尺寸。

5.是否呼叫建構函式/析構函式

new可以,malloc不可以

6.對陣列的處理

c++提供了new與delete來專門處理陣列型別:

7.new與malloc是否可以相互呼叫

operator new /operator delete的實現可以基於malloc,而malloc的實現不可以去呼叫new。

8.是否可以被過載

opeartor new /operator delete可以被過載。

9. 能夠直觀地重新分配記憶體

使用malloc分配的記憶體後,如果在使用過程中發現記憶體不足,可以使用realloc函式進行記憶體重新分配實現記憶體的擴充。realloc先判斷當前的指標所指記憶體是否有足夠的連續空間,如果有,原地擴大可分配的記憶體位址,並且返回原來的位址指標;如果空間不夠,先按照新指定的大小分配空間,將原有資料從頭到尾拷貝到新分配的記憶體區域,而後釋放原來的記憶體區域。

new沒有這樣直觀的配套設施來擴充記憶體。

10. 客戶處理記憶體分配不足

在operator new丟擲異常以反映乙個未獲得滿足的需求之前,它會先呼叫乙個使用者指定的錯誤處理函式,這就是new-handler

總結:特徵

new/delete

malloc/free

分配記憶體的位置

自由儲存區

堆記憶體分配失敗返回值

完整型別指標

void*

記憶體分配失敗返回值

預設丟擲異常

返回null

分配記憶體的大小

由編譯器根據型別計算得出

必須顯式指定位元組數

處理陣列

有處理陣列的new版本new

需要使用者計算陣列的大小後進行記憶體分配

已分配記憶體的擴充

無法直觀地處理

使用realloc簡單完成

是否相互呼叫

可以,看具體的operator new/delete實現

不可呼叫new

分配記憶體時記憶體不足

客戶能夠指定處理函式或重新制定分配器

無法通過使用者**進行處理

函式過載

允許不允許

建構函式與析構函式

呼叫不呼叫

malloc給你的就好像一塊原始的土地,你要種什麼需要自己在土地上來播種

而new幫你劃好了田地的分塊(陣列),幫你播了種(建構函式),還提供其他的設施給你使用:

當然,malloc並不是說比不上new,它們各自有適用的地方。在c++這種偏重oop的語言,使用new/delete自然是更合適的。

new和malloc的區別詳細總結

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

new和malloc的區別

1 new 是c 中的操作符,malloc是c 中的乙個函式 2 new 不止是分配記憶體,而且會呼叫類的建構函式,同理delete會呼叫類的析構函式,而malloc則只分配記憶體,不會進行初始化類成員的工作,同樣free也不會呼叫析構函式 3 記憶體洩漏對於malloc或者new都可以檢查出來的,...

malloc和new的區別

1,malloc與free是c c語言的標準庫函式,new delete是c 的運算子。它們都可用於申請動態記憶體和釋放記憶體。2,對於非內部資料型別的物件而言,光用maloc free無法滿足動態物件的要求。物件在建立的同時要自動執行建構函式,物件在消亡之前要自動執行析構函式。由於malloc f...