Linux編程時(shí)出現(xiàn)Segmentation fault錯(cuò)誤如何解決?
有些開(kāi)發(fā)者在Linux下進(jìn)程編程,使用GDB調(diào)試時(shí)發(fā)現(xiàn)了一個(gè)Segmentation fault錯(cuò)誤。這個(gè)錯(cuò)誤主要是訪問(wèn)了錯(cuò)誤的內(nèi)存段引起的,可能是沒(méi)有權(quán)限或者是內(nèi)存段不存在,這個(gè)問(wèn)題如何處理呢?下面小編將為大家?guī)?lái)Linux編程時(shí)出現(xiàn)Segmentation fault錯(cuò)誤的處理辦法,一起去看看吧。
方法如下:
這個(gè)錯(cuò)誤是怎么導(dǎo)致的呢?原來(lái)是在定義一個(gè)char類型的指針,然后就直接對(duì)這個(gè)指針進(jìn)行字符串的相關(guān)操作。例如:
char *c1;
for(i=0; i《n;i++)
{
*c1 = getchar();
c1++;
}
代碼意思大概是這樣,這是很多開(kāi)發(fā)者會(huì)犯的問(wèn)題。這個(gè)指針危險(xiǎn)啊,要謹(jǐn)慎對(duì)待,就拿這里來(lái)說(shuō),這樣給指針賦值,我們并不知道這指針指向的是哪里呢,如果寫的數(shù)據(jù)覆蓋了關(guān)鍵區(qū)域數(shù)據(jù)那可能會(huì)有災(zāi)難性的后果,這就是訪問(wèn)了不該訪問(wèn)的地方。解決的辦法是什么呢,告訴這個(gè)指針到該到的地方,我用malloc為該指針將要指向的字符串申請(qǐng)一段空間,這樣就會(huì)指明系統(tǒng)分配一段安全的空間,不會(huì)在把內(nèi)存關(guān)鍵區(qū)域分給你了。這樣你就可以安全操作了。
這個(gè)例子告訴我們指針是不能亂用的,如果指針指向錯(cuò)誤的內(nèi)存,導(dǎo)致編程時(shí)出現(xiàn)Segmentation fault錯(cuò)誤,還可以用上面的辦法處理,如果指向其他區(qū)域,還會(huì)導(dǎo)致更嚴(yán)重的后果。
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。