您好,登錄后才能下訂單哦!
1.申請的內存所在的位置 new操作符從自由存儲區上為對象動態分配內存空間,malloc從堆上動態分配內存。 自由存儲區是C++基于new操作符的一個抽象概念,凡是通過new操作符進行進行內存申請,該內存即為自由存儲區。而堆是操作系統所維護的一塊特殊內存,用于程序的動態分配。C語言使用malloc從堆上分配內存,使用free釋放已分配的內存。 而自由存儲區不僅可以是堆,還可以是靜態存儲區,這都看operator new在哪里為對象分配內存。 2.返回類型的安全性 new 內存分配成功時,返回的是對象類型的指針,類型嚴格與對象匹配,無須進行類型轉換,所以new是符合類型安全性的操作符。 malloc 內存分配成功則是返回void*,需要通過強制類型轉換將void*指針轉換成我們需要的類型。 3.內存分配失敗時的返回值 new內存分配失敗時,回拋出bac_alloc異常,不會返回NULL,malloc內存分配失敗時,會返回NULL. 4.是否需要指定內存大小 使用new操作符申請內存分配時無需指定內存塊的大小,編譯器會根據類型信息進行自動計算,而malloc則需要顯式的指出所需內存的大小。 5.是否調用構造函數和析構函數 使用new操作符來分配對象內存時會經歷三個步驟: (1)調用operator new 函數(數組operator new [])分配一塊足夠大的,原始的未命名的內存空間以便存儲特定類型的對象。 (2)編譯器調用構造函數進行初始化; (3)對象構造完成后,返回一個指向該對象的指針。 使用delete操作符來釋放對象內存時會經歷兩個步驟: (1)調用對象的析構函數 (2)編譯器調用operator delete(或operator delete[])函數釋放空間。 6.對數組的處理 C++提供了new[]與delete[]來專門處理數組類型。 new對數組的支持體現在它會分別調用構造函數初始化數組的每一個元素,釋放對象時為每個元素調用析構函數。 至于malloc,它并不知道你在這塊內存上剛的是數組還是其它東西。反正就是給你一塊原始的內存,再給一個內存的地址就完事了。 7.new與malloc是否可以互相調用 operator new/operator delete的實現基于malloc和free,而malloc和free的實現不可以調用new和delete。 8.是否可以被重載 operator new和operator delete可以被重載,malloc和free不可以被重載。 9.能否直觀的重新分配內存 使用malloc分配的內存后,如果在使用過程中發現內存不足,可以使用realloc函數進行內存重新分配,實現內存擴充。new沒有這樣的配套設施來擴充內存。 10.客戶處理內存分配不足 在operator new 拋出異常以反映一個未獲得滿足的需求之前,它會先調用一個用戶指定的錯誤處理函數new-handler, 對于malloc,客戶并不能夠去編程決定內存不足以分配時要干什么事情,只能看著malloc返回NULL.
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。