動態內存管理
我們之前要開辟內存用的方法都是定義變量,比如
但是上述開辟內存的方法有兩個特點
1空間開辟大小是固定的
2數組在申明的時候,必須指定數組的長度,它所需要的內存在編譯時分配
malloc和free
c中提供一個動態內存開辟函數
這個函數向內存申請一塊連續可用的空間,并返回指向這塊空間的指針
這個函數有四個注意的地方
如果傳的參數時負數,因為size_t無符號,所以變為很大的一個數
c中提供另外一個函數free,專門用來做動態內存的釋放和回收
每一個動態開辟后的空間要用free釋放。
除此之外還有realloc
relloc
realloc函數的出現讓動態內存管理更靈活了
realloc能對動態開辟的空間內存大小進行調整
此時就有兩個情況
情況1:原有空間之后有足夠大的空間
情況2:原有空間之后沒有足夠大的
情況1 當是情況1 的時候,要擴展內存就直接原有內存之后直接追加空間,原來空間的數據不發生變化。 情況2 當
是情況2 的時候,原有空間之后沒有足夠多的空間時,擴展的方法是:在堆空間上另找一個合適大小的連續空間來
使用。這樣函數返回的是一個新的內存地址。 由于上述的兩種情況,realloc函數的使用就要注意一些。 舉個例
子:
常見的動態內存錯誤
1對NULL指針的解引用
所以要進行空指針判定
2對動態開辟空間的越界訪問
3對非動態內存開辟使用free釋放
因為定義變量的方法開辟的空間是在棧區上,而動態開辟的是在堆區上
4使用free釋放一塊動態開辟內存的一部分
5對同一塊動態內存多次釋放
6動態開辟內存忘記釋放