成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

經(jīng)典的動態(tài)內(nèi)存錯誤(上)

shadajin / 1738人閱讀

摘要:二內(nèi)存錯誤的類型未判斷動態(tài)內(nèi)存函數(shù)的返回值造成非法訪問申請個類型的空間也可以寫成在此之前未進行返回值判斷,如果是返回值是申請失敗返回的是非法訪問的因為的的地址是隨機的未定的。

目錄

一、前言

二、內(nèi)存錯誤的類型

??1.未判斷動態(tài)內(nèi)存函數(shù)的返回值造成非法訪問

??2.賦值的數(shù)大于申請的內(nèi)存空間造成的越界訪問

??3.free函數(shù)未完全釋放


一、前言

? ? ? ?我們在使用動態(tài)內(nèi)存函數(shù)申請內(nèi)存空間時,需要注意許多細節(jié)如函數(shù)的返回值,

所申請空間的釋放等等,我們要是忽略這些細節(jié)就容易造成程序崩潰、內(nèi)存泄漏、

非法訪問等等一些程序問題。

二、內(nèi)存錯誤的類型

1.未判斷動態(tài)內(nèi)存函數(shù)的返回值造成非法訪問

#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ù)           }

2.賦值的數(shù)大于申請的內(nèi)存空間造成的越界訪問

#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; }

? 下圖時非法訪問的報錯,雖然賦值了,但是呢那塊空間本不屬于我們的,但我們強行賦值,

? 故造成非法訪問,所以我們在寫代碼時要格外注意申請的大小和使用的多少,

? ? 前者須大于等于后者

?3.free函數(shù)未完全釋放

主要原因是返回的的指針不在指向初始位置,或者說指針已經(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

相關(guān)文章

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<