C語言野指針講解
在實(shí)際工程開發(fā)中經(jīng)常會(huì)聽到“野指針”,那么問題來了,什么是野指針?野指針有什么危害?
在介紹野指針之前,先了解一點(diǎn),指針變量的本質(zhì)是值,只不過這個(gè)值有點(diǎn)特殊,是一個(gè)內(nèi)存地址值。
“野指針”指的是指針變量中的值是非法的內(nèi)存地址,但“野指針”不是空指針(NULL),“野指針”指向的內(nèi)存是不可用的,“野指針”往往會(huì)造成內(nèi)存越界、段錯(cuò)誤等問題。
補(bǔ)充:合法的內(nèi)存地址包括定義的變量的地址、malloc函數(shù)申請(qǐng)堆內(nèi)存返回的地址(但未使用free釋放)。
?
介紹過“野指針”的概念后就該了解一下“野指針”的由來,這樣在工程開發(fā)中我們就可以去避免野指的產(chǎn)生。
1、局部指針變量沒有初始化。因?yàn)榫植孔兞坎幌袢肿兞磕菢?,不賦值會(huì)自動(dòng)初始化為0,所以局部指針變量不初始化話的話,指向的是一塊程序員無法把控的內(nèi)存,我們?cè)诙x局部指針變量會(huì)初始化為NULL,局部變量初始化為0。
2、指針?biāo)赶虻淖兞吭谥羔樖褂弥熬捅讳N毀了。最常見的在函數(shù)調(diào)用結(jié)束后返回指向局部變量的指針,所以我們絕對(duì)不要在函數(shù)中返回局部變量和局部數(shù)組的地址,關(guān)于這種情況后續(xù)我再介紹堆棧的時(shí)候再舉例說明。
3、使用已經(jīng)釋放過的指針。比如malloc申請(qǐng)的堆空間通過free釋放后又去調(diào)用該指針,一定要在釋放過后將指針變量的值賦值為NULL。
4、指針運(yùn)算錯(cuò)誤。比如有些情況下雖然初始化或者申請(qǐng)堆空間并未造成“野指針”,但是操作指針不當(dāng)造成指針指向一塊已經(jīng)被別的進(jìn)程使用的內(nèi)存,為避免這種情況,一定要確保字符數(shù)組要以‘\0’結(jié)尾,自己編寫的內(nèi)存相關(guān)函數(shù)指定長度信息(防止內(nèi)存越界)。
5、進(jìn)行了錯(cuò)誤的強(qiáng)制類型轉(zhuǎn)換。比如我們?cè)趯懬度胧匠绦虻臅r(shí)候,會(huì)將int類型的一個(gè)數(shù)據(jù)強(qiáng)制轉(zhuǎn)換成一個(gè)指針類型用來表示寄存器的地址,這個(gè)時(shí)候有可能會(huì)因?yàn)檫@個(gè)數(shù)字取值不當(dāng),正好對(duì)應(yīng)的內(nèi)存已經(jīng)被使用。

版權(quán)聲明:本文為CSDN博主「Rookie Linux」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。版權(quán)歸原作者所有,如有侵權(quán),請(qǐng)聯(lián)系刪除。
原文鏈接:https://blog.csdn.net/qq_37120369/article/details/114770541