動態記憶體分配 malloc,free 函式分析

2021-07-26 20:05:24 字數 1519 閱讀 2015

c語言中的一切操作都是基於記憶體的。

變數和陣列都是記憶體的別名,如何分配這些記憶體由編

譯器在編譯期間決定。

定義陣列的時候必須指定陣列長度。

而陣列長度是在編譯期就必須決定的

但是實際中有需求:

程式執行的過程中,可能需要使用一些額外的記憶體空間。因此就需要採用動態記憶體分配。

malloc和free用於執行動態記憶體分配釋放

malloc所分配的是一塊連續的記憶體,以位元組為單位,並且不帶任何的型別資訊。malloc分配的空間是從系統預留的一整塊空間中申請得到的,這一整塊預留的空間就是堆。

free用於將動態記憶體歸還系統。

在malloc分配記憶體時,還要加上強制型別轉換

malloc不會初始化分配的記憶體。

注意:

• malloc實際分配的記憶體可能會比請求的稍微多一點,但是不能依賴於編譯器的這個行為。

• 當請求的動態記憶體無法滿足時malloc返回null。

• 當free的引數為null時,函式直接返回。

calloc的引數代表所返回記憶體的型別資訊,這是比malloc強大的地方。

calloc會將返回的記憶體初始化為0

realloc用於修改乙個原先已經分配的記憶體塊大小

在使用realloc之後應該使用其返回值

當pointer的第乙個引數為null時,等價於malloc

realloc不會進行初始化。

舉例:

#include 

#include

int main()

pi = (int*)realloc(pi, 10 * sizeof(int));

for(i=0; i<10; i++)

free(pi);

free(ps);

return

0;}

動態記憶體分配是c語言中的強大功能。

程式能夠在需要的時候有機會使用更多的記憶體。

malloc單純的從系統中申請固定位元組大小的記憶體。

calloc能以型別大小為單位申請記憶體並初始化為0。

realloc用於重置記憶體大小。

malloc(0)和calloc(0,……)都不會返回空指標。

動態記憶體分配

在c 中建立乙個物件時,我們必須要為這個物件申請一塊記憶體,而且要用建構函式對這塊記憶體進行初始化。c 中的new和delete相對於c的庫函式malloc和free在這方面有很大的優勢,所以我們主要講的是運算子new和delete。當用new來建立乙個物件時,它會自動在堆裡為物件分配記憶體並且為這...

動態記憶體分配

為什麼使用動態記憶體分配?c語言中的一切操作都是基於記憶體的 變數和陣列都是記憶體的別名,如何分配這些記憶體由編譯器在編譯期間決定 定義陣列的時候必須指定陣列唱的 而陣列長度是在編譯期就必須決定的 需求 程式執行的過程中,可能需要使用一些額外的記憶體空間 malloc和free malloc和fre...

動態記憶體分配

c的儲存類別有4種 自動的 auto 靜態的 statics 暫存器的 register 外部的 extern 全域性變數時分配在記憶體中的靜態儲存區 靜態區域性變數屬於靜態儲存類別,在靜態儲存區內分配儲存單元,是在編譯時賦初值的,只賦初值一次,在程式執行時它已有初值,以後每次呼叫函式時不再重新賦初...