2021.11.18 动态内存中free函数
1. 回顧動態內存基礎知識
#include<stdio.h> #include<stdlib.h> int main() {//動態開辟 10個空間 intint *p = (int*)malloc(10*sizeof(int));assert(p != NULL);if (p == NULL){return 0;}//動態開辟 20個空間 shortshort * p1 = (short*)malloc(20*sizeof(short));assert(p1 != NULL);if (p1 == NULL){return 0;}//動態開辟 100個空間 doubledouble * p2= (double *)malloc(100*sizeof(double));assert(p2 != NULL);if (p2 == NULL){return 0;}//動態開辟 30個空間并初始化為0 intint *p3 = (int*)calloc(30, sizeof(int));assert(p3 != NULL);if (p3 == NULL){return 0;}//動態開辟 50個空間并初始化為'A' charchar * p4 = (char*)malloc(50*sizeof(char));assert(p4 != NULL);if (p4 == NULL){return 0;}for(int i=0; i<50; i++){p4[i] = 'A';//*(p4+i) = 'A';}//將p開辟的內存塊,擴容為40個空間p = (int*)realloc(p, 10*sizeof(int) * 4);int *p5 = (int *)realloc(0, 10*sizeof(int));//相當于malloc: int *p5 = (int*)malloc(10*sizeof(int));//注意 //將p4行開辟的內存塊,再重新縮小為5個p4 = (char*)realloc(p4, 5*sizeof(char));return 0; }2. 自定義修改棧大小為10MB
步驟:項目 → 屬性 → 鏈接器 → 系統 → 堆棧保留大小(改為1024*1024*10,單位是字節)
3. 動態內存的開辟:
優點:可以在程序運行期間,動態的確定開辟內存的大小;可以開辟大的內存塊
malloc:分配內存塊
calloc:分配內存塊,并且全部初始化為0 ? (一般用malloc+for代替calloc)
realloc:調用之前申請的內存塊的大小(可擴充,可縮小),realloc縮小內存塊的話,開頭地址不變,并且其他不要的數據,也沒有變化,只是右邊界線縮小
4.動態內存的釋放:free函數
free函數的必要性:如果動態內存開辟,而使用結束后,沒有釋放,會導致申請的這塊內存沒有人可以使用,?一般將這塊沒有人可以使用的內存叫做“垃圾”,留著垃圾的函數或者程序,會導致出現內存泄露
注意:一個malloc一個free,必須搭配。
free函數出錯的情況:①? 同一塊內存連續釋放 ?
② 釋放這個內存塊,給free的參數并不是它的開始地址 (free釋放內存塊A,但其參數并不是它的開始地址) ? ?
③ free結束后,會造成一個懸空指針
注意:一般來說,free函數執行結束后,立即將其變成空指針,再執行free不會報錯
5. 懸空指針和空指針的區別
懸空指針:也叫野指針,這個指針可能會指向任何一個空間,存在修改的風險,造成不可知的錯誤
空指針:指向0地址的指針 ? 非0即真
6.?C語言有兩個東西,特別危險:數組越界? ? ? 內存泄露
內存泄露或者內存碎片怎么處理:重啟
?
總結
以上是生活随笔為你收集整理的2021.11.18 动态内存中free函数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 怎么把图片无损放大?分享一个图片无损放
- 下一篇: Oracle 11g 新特性:只读表(R