Segmentation fault到底是何方妖孽
生活随笔
收集整理的這篇文章主要介紹了
Segmentation fault到底是何方妖孽
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
那么對于任何沒有經過MMU映射過的虛擬空間的地址,不管進程是執行寫操作還是讀操作,操作系統都會捕捉到這個錯誤的非法訪問,然后輸出一個“Segmetation Fault”的錯誤提示信息并強行終止進程。
程序之所以會時不時的出現“Segmetation Fault”的根本原因是進程訪問到了沒有訪問權限的地方,諸如內核區域或者其0x08048000之前的地方,或者由于要訪問的內存沒有經MMU進行映射所導致。而這種問題比較多的是出在malloc()之類的動態內存申請函數申請完內存,釋放后,沒有將指針設置為NULL,而其他地方在繼續用先前申請的那塊內存時,由于內存管理系統已經將其收回,所以才會出現這樣的問題。良好的關于指針的使用習慣是,使用之前先判斷其是否為NULL,所有已經歸還給操作系統的內存,其訪問指針都要及時置為NULL,防止所謂的“野指針”到處飛的情況,不然在大型項目里,光是圍剿“Segmetation Fault”就要耗費不少兵力。
總結
以上是生活随笔為你收集整理的Segmentation fault到底是何方妖孽的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 难点—在引用数组元素时指针的运算
- 下一篇: visual studio 调试时提示