C程序中可怕的野指針

版權聲明:本文為作者原創文章,轉載時請注明文章來源,否則視為侵權,并按法律程序處理!

一、疑問點

指針是C語言一個很強大的功能,同時也是很容易讓人犯錯的一個功能,用錯了指針,輕者只是報個錯,重者可能整個系統都崩潰了。下面是大家在編寫C程序時,經常遇到的一種錯誤的使用方法,也許在你的學習和工作中就是這樣用的,很危險。實例程序如圖1所示:

圖1 實例程序

這段程序比較簡單,str1指向的內存區域存放了一個字符串“123”,把“123”賦值到str2指向的內存區域,編譯時會給出一個告警:

local variable 'str2' used without having been initialized

意思是說,“str2”這個變量沒有初始化。我們可以不理會這個告警,并且繼續運行程

序,但是“str2”在定義時沒有給初值,是一個野指針,程序運行的結果可能是非常可怕的。下面我們來詳細分析下,野指針的可怕之處。

二、可怕的野指針

我們程序中的

strcpy(str2 , str1);

printf("str2指向的字符串是 %s",str2);

這兩行代碼注釋掉,然后運行程序,看看str2輸出的值是多少。

運行結果如下:

可見str2被系統賦予一個值3435973836,3435973836是一個內存的地址,也就是指針str2指向這段內存,這段內存上保存的數據可能是其他某個程序的數據,例如保存著“hello world!”,如圖2所示,也可能什么數據也沒有。

圖2 其他程序的重要數據

如果這段內存保存著其他程序的重要數據,通過strcopy函數將“123”復制給了這段內存,也就是修改了這個重要數據,這段內存保存的數據變成了“123lo world!”,如圖3所示,那么其他程序可能就崩掉了!

圖3 其他程序的重要數據被改寫

三、避免野指針的方法

為了防止野指針帶來的災難,建議指針在定義時給一個初值,比如“NULL”,意思是不指向任何內存地址。然后再使用malloc函數給指針分配一塊存儲空間。修改的程序如圖4所示:

圖4 避免野指針的改法程序

在定義str2時賦予初值“NULL”,這樣str2就不會指向任何內存。再通過malloc函數,申請一段空的內存區域,也就是沒有任何程序使用的內存區域,讓str2指向這段空的內存區域,如圖5所示,此時再把“123”賦值到這段空的內存區域,這樣就安全了。程序的最后,再主動釋放掉這段內存區域,讓str2再次不指向任何區域。

圖5 系統分配的內存區域

運行結果如圖6所示:

圖6 運行結果

由結果可見,系統分配的沒有任何其他程序使用的內存地址是“2428680”。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容