摘要:二內(nèi)存錯誤的類型未判斷動態(tài)內(nèi)存函數(shù)的返回值造成非法訪問申請個類型的空間也可以寫成在此之前未進行返回值判斷,如果是返回值是申請失敗返回的是非法訪問的因為的的地址是隨機的未定的。
目錄
??1.未判斷動態(tài)內(nèi)存函數(shù)的返回值造成非法訪問
??2.賦值的數(shù)大于申請的內(nèi)存空間造成的越界訪問
? ? ? ?我們在使用動態(tài)內(nèi)存函數(shù)申請內(nèi)存空間時,需要注意許多細節(jié)如函數(shù)的返回值,
所申請空間的釋放等等,我們要是忽略這些細節(jié)就容易造成程序崩潰、內(nèi)存泄漏、
非法訪問等等一些程序問題。
#include#include#includeint main(){ int *p=(*int)malloc(10*sizeof(int));//申請10個int類型的空間也可以寫成malloc(40) for(int i=0;i<10;i++)//在此之前未進行返回值判斷,如果是返回值是NULL(申請失敗返回的),*NULL是 // 非法訪問的因為NULL的的地址是隨機的未定的。 { int kc=*(p+i)=i;//賦值 printf("%d ",kc);//賦值一個打印一個 } free(p); p=NULL; system("pause");//暫停 return 0;}
所以使用動態(tài)內(nèi)存函數(shù)時應(yīng)該先判斷為非空指針才可以進行后續(xù)一系列操作
判斷方法是
//加個if(*p!=NULL) { //要執(zhí)行的語句 } else { return 0;//為NULL直接退出函數(shù) }
#include#includeint main() { char* pp=(char*)calloc(5,sizeof(char));//申請5個char類型的內(nèi)存空間 if(pp!=NULL) { for(int i=0;i<=5;i++)//賦值了6個元素分別是0、1、2、3、4、5動態(tài)函數(shù)只申請了5個 // 剩余一個已經(jīng)越界訪問了。 { int yy =*(pp+i)=i; printf("%d ",yy); } } else { return 0;//為空直接退出函數(shù) } free(pp);//老規(guī)矩,釋放申請的地址,下面那個給你們說 pp=NULL; system("pause"); return 0; }
? 下圖時非法訪問的報錯,雖然賦值了,但是呢那塊空間本不屬于我們的,但我們強行賦值,
? 故造成非法訪問,所以我們在寫代碼時要格外注意申請的大小和使用的多少,
? ? 前者須大于等于后者
主要原因是返回的的指針不在指向初始位置,或者說指針已經(jīng)發(fā)生了變化
#include#includeint main(){ int* ptr=(int*)malloc(10*sizeof(int));//你們應(yīng)該很熟了,我這里就不全部注釋了 if(ptr!=NULL) { for(int i=0;i<10;i++) { int nb=*ptr++=i;//ptr結(jié)束后指向最后一個元素 printf("%d ",nb); } } free(ptr);//此時ptr已經(jīng)不再指向初始位置了,導(dǎo)致free不能完全釋放(釋放了,但沒完全釋放哈哈) ptr=NULL; return 0;}
以下是出錯報的警告(未完全釋放會導(dǎo)致內(nèi)存泄漏)
?改正這個錯誤其實不難,因為他是不記得原來的首地址,所以我們只需要在他改變之前存下
首地址如int* ret=ptr然后釋放ret就可以了.
具體如下:
#include#includeint main(){ int* ptr = (int*)malloc(10 * sizeof(int)); int *ret = ptr; if (ptr != NULL) { for (int i = 0; i<10; i++) { int nb = *ptr++ = i; printf("%d ", nb); } } free(ret); ret=NULL; system("pause"); return 0;}
寫作不易,記得支持一下,歡迎各位大佬斧正
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/119404.html
摘要:如果開辟失敗,則返回一個指針,因此的返回值一定要做檢查。函數(shù)用來釋放動態(tài)開辟的內(nèi)存。 目錄 一、動態(tài)內(nèi)存分配1、為什么存在動態(tài)內(nèi)存分配 二、malloc1、m...
摘要:結(jié)尾有關(guān)這四道經(jīng)典的指針筆試題講解就到此結(jié)束了,如果覺得文章對自己有所幫助,歡迎大家多多點贊收藏 ?前言 : 今天博主來講解4道經(jīng)典的指針筆試題,很多朋友沒有深刻理...
閱讀 2588·2021-09-22 15:25
閱讀 3001·2021-09-14 18:03
閱讀 1268·2021-09-09 09:33
閱讀 1739·2021-09-07 09:59
閱讀 2961·2021-07-29 13:50
閱讀 1527·2019-08-30 15:44
閱讀 1742·2019-08-29 16:22
閱讀 1316·2019-08-29 12:49