常見記憶體開闢的基本方式,如下:
int val =20;
//在棧空間上開闢四個位元組
char arr[10]
=;//在棧空間上開闢10個位元組的連續空間
但是上述的開闢空間的方式有兩個特點:
空間開闢大小是固定的。但是對於空間的需求,不僅僅是上述的情況。有時候我們需要的空間大小在程式執行的時候才能知道,那陣列的編譯時開闢空間的方式就不能滿足了。 這時候就只能試試動態存開闢了。陣列在申明的時候,必須指定陣列的長度,它所需要的內存在編譯時分配。
1. malloc和free
void
* malloc (size_t size)
;
malloc函式用於向記憶體申請一塊連續可用的空間,並返回指向這塊空間的指標。
1.如果開闢成功,則返回乙個指向開闢好空間的指標。2.如果開闢失敗,則返回乙個null指標,因此malloc的返回值一定要做檢查。
3.返回值的型別是 void*,所以malloc函式並不知道開闢空間的型別,具體在使用的時候使用者自己來決定。
4. 如果引數 size為0,malloc的行為是標準是未定義的,取決於編譯器。
void free (
void
* ptr)
;
free函式是用來專門做動態記憶體的釋放和**。
1.如果引數 ptr 指向的空間不是動態開闢的,那free函式的行為是未定義的。2. calloc2.如果引數 ptr 是null指標,則函式什麼事都不做。
void
* calloc (size_t num, size_t size)
;
calloc 函式也用來動態記憶體分配。
1.函式的功能是為 num 個大小為 size 的元素開闢一塊空間,並且把空間的每個位元組初始化為0。3.realloc2.與函式 malloc 的區別只在於 calloc 會在返回位址之前把申請的空間的每個位元組初始化為全0。
void
* realloc (
void
* ptr, size_t size)
;
realloc函式的出現讓動態記憶體管理更加靈活。有時會我們發現過去申請的空間太小了,有時候我們又會覺得申請的空間過大了,那為了合理的時候記憶體,我們一定會對記憶體的大小做靈活的調整。realloc 函式就可以做到對動態開闢記憶體大小的調整。
1.ptr 是要調整的記憶體位址。1.對null指標的解引用操作。2.size 調整之後新大小。
3.返回值為調整之後的記憶體起始位置。
4.這個函式調整原記憶體空間大小的基礎上,還會將原來記憶體中的資料移動到新的空間。
void
test()
2.對動態開闢空間的越界訪問。
void
test()
for(i=
0; i<=
10; i++
)free
(p);
}
3.對非動態記憶體使用free釋放。
void
test()
4.使用free釋放一塊動態開闢記憶體的一部分。
void
test()
5.對同一塊記憶體多次釋放。
void
test()
6.動態開闢記憶體忘記釋放(記憶體洩漏)。
void
test()
}int
main()
忘記釋放不再使用的動態開闢的空間會造成記憶體洩漏。
注意:動態開闢的空間一定要釋放,並且正確釋放 。
C語言動態記憶體管理
1 概述 動態儲存管理的基本問題是 系統如何按請求分配記憶體,如何 記憶體再利用。提出請求的使用者可能是系統的乙個作業,也可能是程式中的乙個變數。空閒塊 未曾分配的位址連續的記憶體區稱為 空閒塊 占用塊 已分配給使用者使用的位址連續的記憶體區稱為 占用塊 系統剛剛啟動時,整個記憶體可看做乙個大的 空...
C語言動態記憶體管理
c系統的函式庫中提供了了程式動態申請和釋放記憶體儲存塊的庫函式,下面將分別介紹。1 malloc 函式 a 該函式的原型 void malloc size t size b 該函式只有乙個引數,且形參size是無符號整型,該引數代表申請空間的位元組數。c 返回值 如果記憶體池中的可用記憶體滿足需求,...
C語言動態記憶體管理
在說明c語言記憶體管理之前,要知道什麼是記憶體,記憶體我個人認為可以理解為帶有標籤的盒子,所謂的帶標籤的盒子就像我們住的寢室一樣有門牌號,盒子內只能儲存固定型別的資料或變數,就如男生寢室只能住男生一樣。那麼c語言中有多少種盒子呢?有靜態儲存區 動態儲存區 內部暫存器區域。我們通常定義的變數如果沒有特...