為什麼存在動態記憶體分配
通常我們記憶體開闢的方式為:
int a =20;
//在棧空間上開闢四個位元組
char arr[10]
=;//在棧空間上開闢10個位元組的連續空
上述的開闢空間的方式有兩個特點:
1. 空間開闢大小是固定的。
2. 陣列在申明的時候,必須指定陣列的長度,它所需要的內存在編譯時分配。
但是對於空間的需求,有時候我們需要的空間大小在程式執行的時候才能知道,那陣列的編譯時開闢空間的方式就不能滿足了。 這便要使用動態記憶體。
動態記憶體函式
malloc
void
* malloc (size_t size)
;
這個函式向記憶體申請一塊連續可用的空間,並返回指向這塊空間的指標。
free
函式free專門用來做動態記憶體的釋放和**的
void free (
void
* ptr)
;
calloc
void
* calloc (size_t num, size_t size)
;
realloc原地擴容
void
* realloc (
void
* ptr, size_t size)
;
情況1:原有空間之後有足夠大的空間
情況2:原有空間之後沒有足夠大的空間
注意:
* 忘記釋放不再使用的動態開闢的空間會造成記憶體洩漏,
* 動態開闢的空間一定要釋放,並且正確釋放
c/c++程式的記憶體開闢
c/c++程式記憶體分配的幾個區域:
- 棧區(stack):在執行函式時,函式內區域性變數的儲存單元都可以在棧上建立,函式執行結束時這些儲存單元自動被釋放。棧記憶體分配運算內置於處理器的指令集中,效率很高,但是分配的記憶體容量有限。 棧區主要存放執行函式而分配的區域性變數、函式引數、返回資料、返回位址等。
- 堆區(heap):一般由程式設計師分配釋放, 若程式設計師不釋放,程式結束時可能由os** 。分配方式類似於鍊錶。
- 資料段(靜態區)(static)存放全域性變數、靜態資料。程式結束後由系統釋放。
- **段:存放函式體(類成員函式和全域性函式)的二進位制**。
C語言動態記憶體管理
1 概述 動態儲存管理的基本問題是 系統如何按請求分配記憶體,如何 記憶體再利用。提出請求的使用者可能是系統的乙個作業,也可能是程式中的乙個變數。空閒塊 未曾分配的位址連續的記憶體區稱為 空閒塊 占用塊 已分配給使用者使用的位址連續的記憶體區稱為 占用塊 系統剛剛啟動時,整個記憶體可看做乙個大的 空...
C語言動態記憶體管理
c系統的函式庫中提供了了程式動態申請和釋放記憶體儲存塊的庫函式,下面將分別介紹。1 malloc 函式 a 該函式的原型 void malloc size t size b 該函式只有乙個引數,且形參size是無符號整型,該引數代表申請空間的位元組數。c 返回值 如果記憶體池中的可用記憶體滿足需求,...
C語言動態記憶體管理
在說明c語言記憶體管理之前,要知道什麼是記憶體,記憶體我個人認為可以理解為帶有標籤的盒子,所謂的帶標籤的盒子就像我們住的寢室一樣有門牌號,盒子內只能儲存固定型別的資料或變數,就如男生寢室只能住男生一樣。那麼c語言中有多少種盒子呢?有靜態儲存區 動態儲存區 內部暫存器區域。我們通常定義的變數如果沒有特...