C 動態記憶體管理

2021-07-13 19:24:18 字數 1719 閱讀 6186

我們都知道在c++中可以用new/malloc動態分配記憶體空間,delete/free釋放動態開闢的記憶體空間。

1. 那麼既然c++中有了可以動態開闢記憶體的函式為什麼又要有new/delete呢?

c++中的malloc/free是繼承c語言中的malloc/free,它的用法和在c語言中的用法一模一樣。

malloc只是單純的開闢記憶體空間而不進行初始化,free只是將動態開闢的記憶體空間給釋放了。

對於內建型別來說,malloc/free開闢和釋放記憶體沒有任何問題;對於非內建型別而言,由於物件建立過程中呼叫建構函式進行初始化,在物件的消除時要呼叫析構函式進行一些清理工作,顯然,malloc/free無法完成這些事情。

因此,c++提供了new/delete兩個操作符,用new在動態分配記憶體的時候呼叫建構函式進行初始化,delete在釋放記憶體的時候自動呼叫析構函式進行清理。

2.new/delete的使用

a為非內建型別

class a

int main()

非內建型別

a為上面的自定義類

void funtest1()

int main()

對上述現象

分析:追蹤   int *pa = new int[10];   發現呼叫operator new(size_t count)函式

追蹤    a*pb = new a[10];  發現 呼叫  operator new(size_t count) 函式

對上述現象

總結:說明了new在開闢內建型別的空間時,開闢得空間數量是指定的空間數量,位元組數是指定的數量乘以型別的大小。

而在開闢非內建型別空間時,除了開闢指定數量的空間以外,還多開闢4個位元組的空間。

為什麼這這裡是84呢?(前面可以知道sizeof(a)為8)

new開闢非內建型別的空間時傳給operator new(size_t count)的count是型別的大小*空間的數量在加上4個位元組,最前面的空間裡放的是要執行析構函式的次數。它返回給a2的位址是最前面的空間的後乙個空間的位址。

所以很容易理解內建型別new/delete,new/delete 交錯使用可以:內建型別沒有析構函式,所以不需要開闢

通過除錯,看看記憶體中有什麼:

對於delete:

非內建型別用delete在釋放空間時呼叫operator delete(char *p),而此時的p被編譯器內部處理過後,它指向的是這些連續空間的最前面乙個空間的位址,因此,而傳給operator delete(char *p)的位址是處理過後的位址,因此,他可以釋放一塊連續的空間並且直到呼叫析構函式的次數。

而如果用delete,則直接呼叫operator delete(char *p),傳給p的位址是a2的位址,如果釋放它,就相當於釋放動態開闢空間的一部分,這樣會造成記憶體洩露,使程式崩潰,而編譯器不知道呼叫多少次析構函式。

C 動態記憶體管理

1 總結並剖析malloc free和new delete之間關係和差異。1 他們都是動態記憶體管理的入口 2 malloc要計算空間大小,返回值要強轉 new自動計算位元組大小,返回值是相應型別的指標 3 malloc只開闢空間 new開闢空間 呼叫建構函式初始化 delete呼叫析構函式清理 釋...

c 動態記憶體管理

c語言動態記憶體管理 c中關於動態記憶體的標準庫函式 malloc calloc realloc free 以下是關於這幾個函式的介紹 1 malloc 用於動態開闢記憶體 堆空間 返回型別為void 引數 size t size 是無符號整型表示要開闢的空間大小,單位是位元組,2 calloc 用...

c 動態記憶體管理

c語言動態記憶體管理 c語言使用malloc calloc realloc free進行動態記憶體管理 malloc是不初始化的開闢空間,其引數為空間的大小,單位為位元組 calloc是初始化的進行開闢空間,其引數為 元素個數,大小 單位為位元組。realloc增容,如果後面的空間足夠的話,就直接追...