深入理解C++中的new/delete和malloc/free動態記憶體管理及區別介紹
阿新 • • 發佈:2020-09-01
malloc/free和new/delete的區別
- malloc/free是C/C++標準庫的函式;new/delete是C++操作符。
- malloc/free只是動態分配記憶體空間/釋放空間;new/delete除了分配空間還會呼叫建構函式和解構函式進行初始化與清理資源。
- malloc/free需要手動計算型別大小且返回值型別為
void*
;new/delete可自動計算型別的大小,返回對應型別的指標。 - malloc/free管理記憶體失敗會返回0;new/delete等的方式管理記憶體失敗會丟擲異常。
在C++ Primer書中有提到說: new/delete的表示式與標準庫函式同名了,所以系統並沒有過載new或delete表示式。new/delete真正的實現其實是依賴下面這幾個記憶體管理介面的。
void *operator new(size_t); //allocate an object void *operator delete(void *); //free an object void *operator new[](size_t); //allocate an array void *operator delete[](void *); //free an array
malloc/free和new/delete的底層實現
new的底層實現
// new.cpp #include <cstdlib> #include <new> _C_LIB_DECL int __cdecl _callnewh(size_t size) _THROW1(_STD bad_alloc); _END_C_LIB_DECL void *__CRTDECL operator new(size_t size) _THROW1(_STD bad_alloc) { // try to allocate size bytes void *p; while ((p = malloc(size)) == 0) if (_callnewh(size) == 0) { // report no memory _THROW_NCEE(_XSTD bad_alloc,); } return (p); }
delete的底層實現
#include <cruntime.h> #include <malloc.h> #include <new.h> #include <windows.h> #include <rtcsup.h> void operator delete( void * p ) { RTCCALLBACK(_RTC_Free_hook,(p,0)); free( p ); }
new[]的底層實現
#include <new> void *__CRTDECL operator new[](size_t count) _THROW1(std::bad_alloc) { // try to allocate count bytes for an array return (operator new(count)); }
delete[]的底層實現
#ifdef CRTDLL #undef CRTDLL #endif #ifdef MRTDLL #undef MRTDLL #endif #define _USE_ANSI_CPP // suppress defaultlib directive for Std C++ Lib #include <new> extern void __CRTDECL operator delete[](void *ptr) _THROW0(); void __CRTDECL operator delete[](void *ptr,const std::nothrow_t&) _THROW0() { // free an allocated object operator delete[](ptr); }
malloc/free和new/delete的執行過程
new的執行過程
new(int size) --> operator new() --> malloc() --> constructor function --> return ptr
delete的執行過程
delete ptr --> destructor function --> operator delete() --> free
new[]的執行過程
new[count] --> operator new[]() --> operator new() --> malloc() --> constructor function --> return ptr
delete[]的執行過程
delete[] ptr --> destructor function --> operator delete[]() --> operator delete() --> free
- 依次呼叫指標指向物件陣列中每個物件的解構函式
- 呼叫
operator delete[]()
,operator delete[]()
再呼叫operator delete
- 底層用free執行
operator delete
表示式,依次釋放記憶體 operator delete[]()
陣列的個數存放在指標的前4位
參考
https://www.jb51.net/article/161885.htm
總結
到此這篇關於深入理解C++中的new/delete和malloc/free動態記憶體管理的文章就介紹到這了,更多相關C++中的new/delete和malloc/free動態記憶體管理內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!