您好,登錄后才能下訂單哦!
一、疑問點
指針是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”。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。