溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C語言最短的崩潰程序分析

發(fā)布時(shí)間:2021-11-22 16:22:41 來源:億速云 閱讀:123 作者:iii 欄目:編程語言

本篇內(nèi)容主要講解“C語言最短的崩潰程序分析”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“C語言最短的崩潰程序分析”吧!

通常學(xué)生們要么嘗試反向引用一個(gè)非法地址,要么就是除0.除0會(huì)引發(fā)SIGFPE信號(浮點(diǎn)異常)。這里有一個(gè)小例子程序,使用除零方法來使之崩潰:

int main()  {      return 1/0;  }

我們也可以刪掉return關(guān)鍵字,但是當(dāng)我這么做的時(shí)候gcc不會(huì)為這些語句生成可執(zhí)行代碼,即便優(yōu)化選項(xiàng)被disable掉了。我們還可以通過把上面的語句改成賦值語句,使上面的代碼改變一些特征:

i;  int main()  {      i=1/0;  }

注意我聲明了一個(gè)沒有類型的i。這樣的代碼在C89標(biāo)準(zhǔn)里是有效的,因?yàn)樗械穆暶鞫加须[形的缺省類型int。在C99和其他一些C標(biāo)準(zhǔn)里這是一個(gè)錯(cuò)誤。假定我們寫的是C89代碼,那么我們甚至可以使用隱形int來聲明main函數(shù):

i;  main()  {      i=1/0;  }

那是相當(dāng)短的代碼了 — 如果我們不把用于縮進(jìn)的空格計(jì)算進(jìn)來,只有16個(gè)字符。然而,我們還可以做得更好!

當(dāng)C程序在編譯的時(shí)候,編譯器會(huì)產(chǎn)生一個(gè)或更多對象文件,文件里有對于用到的庫和全程對象(函數(shù)和變量)的符號索引。然后這些對象文件會(huì)被進(jìn)行鏈接,這時(shí)符號索引被地址所代替,就產(chǎn)生了一個(gè)可執(zhí)行文件。

編譯器在一個(gè)對象文件里提供了一個(gè)調(diào)用main函數(shù)的入口點(diǎn)。調(diào)用main函數(shù)意味著我們試圖執(zhí)行在存儲在main函數(shù)鏈接的位置所對應(yīng)地址里的指令。

有趣的是,鏈接器對于不同對象的類型是沒有概念的,它只知道它們的地址。所以,如果我們用一個(gè)常規(guī)的全程變量替換main函數(shù),編譯器會(huì)高興地build對象文件,因?yàn)樗魂P(guān)心對象main的類型是什么;鏈接器也會(huì)高興地鏈接它,因?yàn)樗魂P(guān)心main函數(shù)對應(yīng)的地址。

所以,考慮這個(gè)C程序:

int main=0;

這個(gè)程序會(huì)編譯成一個(gè)可執(zhí)行文件,它會(huì)試圖調(diào)用地址0,而0并不是我們能夠訪問的地址,這樣我們會(huì)得到SIGSEGV信號(分段錯(cuò)誤)。

更正:我前面關(guān)于這個(gè)程序崩潰的原因分析是錯(cuò)的。這個(gè)程序會(huì)試圖按函數(shù)方式去執(zhí)行main,而這樣不會(huì)奏效,因?yàn)榫幾g器把它放到了不可執(zhí)行的數(shù)據(jù)段。所以變量main初始化為什么值都無所謂了。(感謝Zack的糾正)

現(xiàn)在我們已經(jīng)非常接近最小的崩潰的C程序了。我們可以利用這個(gè)技巧,配合隱形int類型,來把它進(jìn)一步縮短。

main=0;

還有,C里的全局變量都會(huì)隱形地初始化為0,所以上面的代碼就等同于:

main;

好了,現(xiàn)在我們得到了最短的崩潰的C程序!

補(bǔ)充:

Hacker News用戶femto指出,編譯和鏈接一個(gè)空文件也是可能的。我沒有發(fā)布這個(gè)是因?yàn)間cc會(huì)拒絕編譯和鏈接這樣的程序,它會(huì)要求分開編譯和鏈接的過程。

到此,相信大家對“C語言最短的崩潰程序分析”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI