c語言提供了乙個動態記憶體開闢的函式:
void malloc (size_t size);*
這個函式向記憶體申請一塊連續可用的空間,並返回指向這塊空間的指標。
1.如果開闢成功,則返回乙個指向開闢好空間的指標。
2.如果開闢失敗,則返回乙個null指標,因此malloc的返回值一定要做檢查。
3.返回值的型別是 void* ,所以malloc函式並不知道開闢空間的型別,具體在使用的時候使用者自己來決定。
4.如果引數 size 為0,malloc的行為是標準是未定義的,取決於編譯器。
c語言提供了另外乙個函式free,專門是用來做動態記憶體的釋放和**的,函式原型如下:
void free(void ptr);*
free函式用來釋放動態開闢的記憶體。
1.如果引數 ptr 指向的空間不是動態開闢的,那free函式的行為是未定義的。
2.如果引數 ptr 是null指標,則函式什麼事都不做
*c語言還提供了乙個函式叫 calloc , calloc 函式也用來動態記憶體分配
void calloc (size_t num, size_t size);
**1.函式的功能是為 num 個大小為 size 的元素開闢一塊空間,並且把空間的每個位元組初始化為0。
2.與函式 malloc 的區別只在於 calloc 會在返回位址之前把申請的空間的每個位元組初始化為全0
realloc
void realloc(void ptr, size_t size);**
1.realloc函式的出現讓動態記憶體管理更加靈活。
2.有時會我們發現過去申請的空間太小了,有時候我們又會覺得申請的空間過大了,那為了合理的時候記憶體,我們一定會對記憶體的大小做靈活的調整。那 realloc 函式就可以做到對動態開闢記憶體大小的調整。
3.ptr 是要調整的記憶體位址
4.size 調整之後新大小
5.返回值為調整之後的記憶體起始位置。
6.這個函式調整原記憶體空間大小的基礎上,還會將原來記憶體中的資料移動到 新 的空間。
7.realloc在調整記憶體空間的是存在兩種情況:
情況1:原有空間之後有足夠大的空間
情況2:原有空間之後沒有足夠大的空間
c99 中,結構體中的最後乙個元素允許是未知大小的陣列,這就叫做『柔性陣列』成員
**
typedef
struct st_type
type_a;
柔性陣列的特點:
1.結構中的柔性陣列成員前面必須至少乙個其他成員。
2.sizeof 返回的這種結構大小不包括柔性陣列的記憶體。
3.包含柔性陣列成員的結構用malloc ()函式進行記憶體的動態分配,並且分配的記憶體應該大於結構的大小,以適應柔性陣列的預期大小
C語言動態記憶體管理
1 概述 動態儲存管理的基本問題是 系統如何按請求分配記憶體,如何 記憶體再利用。提出請求的使用者可能是系統的乙個作業,也可能是程式中的乙個變數。空閒塊 未曾分配的位址連續的記憶體區稱為 空閒塊 占用塊 已分配給使用者使用的位址連續的記憶體區稱為 占用塊 系統剛剛啟動時,整個記憶體可看做乙個大的 空...
C語言動態記憶體管理
c系統的函式庫中提供了了程式動態申請和釋放記憶體儲存塊的庫函式,下面將分別介紹。1 malloc 函式 a 該函式的原型 void malloc size t size b 該函式只有乙個引數,且形參size是無符號整型,該引數代表申請空間的位元組數。c 返回值 如果記憶體池中的可用記憶體滿足需求,...
C語言動態記憶體管理
在說明c語言記憶體管理之前,要知道什麼是記憶體,記憶體我個人認為可以理解為帶有標籤的盒子,所謂的帶標籤的盒子就像我們住的寢室一樣有門牌號,盒子內只能儲存固定型別的資料或變數,就如男生寢室只能住男生一樣。那麼c語言中有多少種盒子呢?有靜態儲存區 動態儲存區 內部暫存器區域。我們通常定義的變數如果沒有特...