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