全面講述Fedora proc系統(tǒng)調(diào)試
Fedora 有很多值得學(xué)習(xí)的地方,這里我們主要介紹Fedora proc系統(tǒng)調(diào)試,包括介紹GDB等方面。一旦使用GDB掛上被調(diào)試程序,當(dāng)程序運(yùn)行起來(lái)后,你可以根據(jù)自己 的調(diào)試思路來(lái)動(dòng)態(tài)地在GDB中更改當(dāng)前被調(diào)試程序的運(yùn)行線路或是其 變量的值,這個(gè)強(qiáng)大的功能能夠讓你更好的Fedora proc系統(tǒng)調(diào)試你的程序,比如,你 可以在程序的一次運(yùn)行中走遍程序的所有分支。
修改變量值
修改被Fedora proc系統(tǒng)調(diào)試程序運(yùn)行時(shí)的變量值,在GDB中很容易實(shí)現(xiàn),使用GDB的print命令即可完成。如:(gdb) print x=4
x=4這個(gè)表達(dá)式是C/C++的語(yǔ)法,意為把變量x的值修改為4,如果你當(dāng)前Fedora proc系統(tǒng)調(diào)試的語(yǔ)言是Pascal,那么你可以使用Pascal的語(yǔ)法:x:=4。
在某些時(shí)候,很有可能你的變量和GDB中的參數(shù)沖突,如:
(gdb) whatis widthtype = double(gdb) p width$4 = 13(gdb) set width=47Invalid syntax in expression.
因?yàn)椋瑂et width是GDB的命令,所以,出現(xiàn)了“Invalid syntax inexpression”的設(shè)置錯(cuò)誤,此時(shí),你可以使用set var命令來(lái)告訴GDB,width不是你GDB的參數(shù),而是程序的變量名,如:
(gdb) set var width=47
另外,還可能有些情況,GDB并不報(bào)告這種錯(cuò)誤,所以保險(xiǎn)起見(jiàn),在你改變程序變量取值時(shí),最好都使用set var格式的GDB命令。
跳轉(zhuǎn)執(zhí)行
一般來(lái)說(shuō),被Fedora proc系統(tǒng)調(diào)試程序會(huì)按照程序代碼的運(yùn)行順序依次執(zhí)行。GDB提供了亂序執(zhí)行的功能,也就是說(shuō),GDB可以修改程序的執(zhí)行順序,可以讓程序執(zhí)行隨意跳躍。這個(gè)功能可以由GDB的jump命令來(lái)完:
jump 指定下一條語(yǔ)句的運(yùn)行點(diǎn)。可以是文件的行號(hào),可以是file:line格式,可以是+num這種偏移量格式。表式著下一條運(yùn)行語(yǔ)句從哪里開(kāi)始。
jump
這里的是代碼行的內(nèi)存地址。注意,jump命令不會(huì)改變當(dāng)前的程序棧中的內(nèi)容,所以,當(dāng)你從一個(gè)函數(shù)跳到另一個(gè)函數(shù)時(shí),當(dāng)函數(shù)運(yùn)行完返回時(shí)進(jìn)行彈棧操作時(shí)必然會(huì)發(fā)生錯(cuò)誤,可能結(jié)果還是非常奇怪的,甚至于產(chǎn)生程序Core Dump。所以最好是同一個(gè)函數(shù)中進(jìn)行跳轉(zhuǎn)。
熟悉匯編的人都知道,程序運(yùn)行時(shí),有一個(gè)寄存器用于保存當(dāng)前代碼所在的內(nèi)存地址。所以,jump命令也就是改變了這個(gè)寄存器中的值。于是,你可以使用“set $pc”來(lái)更改跳轉(zhuǎn)執(zhí)行的地址。如:
set $pc = 0x485
產(chǎn)生信號(hào)量
使用singal命令,可以產(chǎn)生一個(gè)信號(hào)量給被Fedora proc系統(tǒng)調(diào)試的程序。如:中斷信 號(hào)Ctrl+C。這非常方便于程序的調(diào)試,可以在程序運(yùn)行的任意位置 設(shè)置斷點(diǎn),并在該斷點(diǎn)用GDB產(chǎn)生一個(gè)信號(hào)量,這種精確地在某處產(chǎn) 生信號(hào)非常有利程序的調(diào)試。
語(yǔ)法是:signal ,UNIX的系統(tǒng)信號(hào)量通常從1到15。所以取值也在這個(gè)范圍。
single命令和shell的kill命令不同,系統(tǒng)的kill命令發(fā)信號(hào)給被Fedora proc系統(tǒng)調(diào)試程序時(shí),是由GDB截獲的,而single命令所發(fā)出一信號(hào)則是直接發(fā)給被調(diào)試程序的。
強(qiáng)制函數(shù)返回
如果你的Fedora proc系統(tǒng)調(diào)試斷點(diǎn)在某個(gè)函數(shù)中,并還有語(yǔ)句沒(méi)有執(zhí)行完。你可以使用return命令強(qiáng)制函數(shù)忽略還沒(méi)有執(zhí)行的語(yǔ)句并返回。
returnreturn 使用return命令取消當(dāng)前函數(shù)的執(zhí)行,并立即返回,如果指定了,那么該表達(dá)式的值會(huì)被認(rèn)作函數(shù)的返回值。
強(qiáng)制調(diào)用函數(shù)
call 表達(dá)式中可以一是函數(shù),以此達(dá)到強(qiáng)制調(diào)用函數(shù)的目的。并顯示函數(shù)的返回值,如果函數(shù)返回值是void,那么就不顯示。
另一個(gè)相似的命令也可以完成這一功能——print,print后面可以跟表達(dá)式,所以也可以用他來(lái)調(diào)用函數(shù),print和call的不同是,如果函數(shù)返回void,call則不顯示,print則顯示函數(shù)返回值,并把該值存入歷史數(shù)據(jù)中。
在不同語(yǔ)言中使用GDB
GDB 支持下列語(yǔ)言:C, C++, Fortran, PASCAL, Java, Chill,assembly, 和 Modula-2。一般說(shuō)來(lái),GDB會(huì)根據(jù)你所Fedora proc系統(tǒng)調(diào)試的程序來(lái)確定當(dāng)然的Fedora proc系統(tǒng)調(diào)試語(yǔ)言,比如:發(fā)現(xiàn)文件名后綴為“.c”的,GDB會(huì)認(rèn)為是C程序。文件名后綴為 “.C, .cc, .cp, .cpp, .cxx, .c++”的,GDB會(huì)認(rèn)為是C++程序。而后綴是“.f, .F”的,GDB會(huì)認(rèn)為是Fortran程序,還有,后綴為如果是“.s, .S”的會(huì)認(rèn)為是匯編語(yǔ)言。
也就是說(shuō),GDB會(huì)根據(jù)你所調(diào)試的程序的語(yǔ)言,來(lái)設(shè)置自己的語(yǔ)言環(huán)境,并讓GDB的命令跟著語(yǔ)言環(huán)境的改變而改變。比如一些GDB命令需要用到表達(dá)式或變量時(shí),這些表達(dá)式或變量的語(yǔ)法,完全是根據(jù)當(dāng)前的語(yǔ)言環(huán)境而改變的。例如C/C++中對(duì)指針的語(yǔ)法是*p,而在Modula-2中則是p^。并且,如果你當(dāng)前的程序是由幾種不同語(yǔ)言一同編譯成的,那到在Fedora proc系統(tǒng)調(diào)試過(guò)程中,GDB也能根據(jù)不同的語(yǔ)言自動(dòng)地切換語(yǔ)言環(huán)境。這種跟著語(yǔ)言環(huán)境而改變的功能,真是體貼開(kāi)發(fā)人員的一種設(shè)計(jì)。
下面是幾個(gè)相關(guān)于GDB語(yǔ)言環(huán)境的命令:
show language查看當(dāng)前的語(yǔ)言環(huán)境。如果GDB不能識(shí)為你所Fedora proc系統(tǒng)調(diào)試的編程語(yǔ)言,那么,C語(yǔ)言被認(rèn)為是默認(rèn)的環(huán)境。
info frame查看當(dāng)前函數(shù)的程序語(yǔ)言。
info source查看當(dāng)前文件的程序語(yǔ)言。
如果GDB沒(méi)有檢測(cè)出當(dāng)前的程序語(yǔ)言,那么你也可以手動(dòng)設(shè)置當(dāng)前的程序語(yǔ)言。使用set language命令即可做到。
當(dāng)set language命令后什么也不跟的話,你可以查看GDB所支持的語(yǔ)言種類:
(gdb) set languageThe currently understood settings are:
local or auto Automatic setting based on source filec Use the C languagec++ Use the C++ langua ...
【編輯推薦】