new 與malloc申請記憶體區別

2021-08-31 01:36:32 字數 1272 閱讀 8942

首先我們需要了解堆與棧的概念。

區分堆記憶體與棧記憶體的區別。

以及堆與棧訪問速度的差異的原因。

1.屬性:

new/delete是c++關鍵字,需要編譯器支援。malloc/free是庫函式,需要標頭檔案支援。

2.引數:

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

3.返回型別:

new操作符記憶體分配成功時,返回的時物件型別的指標,型別嚴格與物件匹配,無須進行型別轉換,故new是符合型別安全性的操作符。

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

4.分配失敗:

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

5.自定義型別:

new會先呼叫operator new 函式,申請足夠的記憶體(通常底層使用malloc實現)。然後呼叫型別的建構函式,初始化成員變數,最後返回自定義類析構指標。delete線呼叫析構函式,然後呼叫operator delete函式釋放記憶體(通常底層使用free實現)。

malloc/free時庫函式,智慧型動態的申請和釋放記憶體,無法強制要求其左自定義型別物件構造和析構工作。

6.過載:

c++允許過載new /delete操作符,特別時,布局new的就不需要為物件分配記憶體,而是制定了乙個位址作為記憶體起始區域,new再這段記憶體上為物件呼叫建構函式完成初始化工作,並返回此位址。而malloc不允許過載。

7.記憶體區域:

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

8.c++記憶體管理方式:

堆、棧、自由儲存區、全域性\\靜態儲存區、常量儲存區

自由儲存區,就是那些由malloc等分配的記憶體塊,他和堆是十分相似的,不過它是用free來結束自己的生命的。

自由儲存區//堆:free 和malloc用在堆上,有些編譯器中new和delete用的是free和malloc去申請的內存在堆上,但是如果通過過載操作符,改變其他記憶體實現自由儲存,例如全域性變數做的物件池,這時自由儲存區就區別於堆了。堆與自由儲存區並不完全等價

new與delete申請記憶體

malloc申請而來的只是記憶體,嚴格地說並不是 物件 new delete的引用就是要解決malloc帶來的問題 4個int,16個位元組 int p int malloc 16 for int i 0 i 4 i 在c 中,用new delete操作符取代malloc free 申請乙個物件 i...

C 中new和malloc記憶體區問題

參考如下 這裡有解釋 基本上來說,很多編譯器都是預設new是呼叫malloc來開闢記憶體的,那麼都是呼叫malloc來開闢乙個記憶體區的那麼問題來了。這個時候到底是自由記憶體區還是堆記憶體?自由記憶體區在c中是沒有的,在c 中才被提及的乙個抽象概念。那麼在一般情況下不過載修改開闢方式或者說開闢記憶體...

new和malloc申請記憶體失敗後的處理

1.c 標準 new 失敗是丟擲異常的,visual c 6.0中返回乙個null指標.使用new std nothrow 可以保證失敗時返回null 因此完全可以 define new new std nothrow 2.使用 malloc calloc 等分配記憶體的函式時,一定要檢查其返回值是...