第一步,編譯生成帶源代碼調試符號的可執行文件:
gcc –o hello –g hello.c
其中-g的意思是生成帶源代碼調試符號的可執行文件hello,不使用-g進行編譯的可執行文件也可以使用gdb調試,但是缺少部分調試信息(如行號、函數名等)。調試信息包括用戶程序里的每個變量的類型和在可執行文件里的地址映射以及源代碼的行號。
第二,使用gdb hello進入gdb,進行調試階段。啟動gdb有以下幾種方式:
gdb filename //指定要調試的程序
gdb filename core //指定要調試的程序及其coredump文件
gdb filename pid //指定要調試的程序及對應進程id號
可以使用命令行參數更加詳細地控制gdb的行為:
-silent //不顯示進入gdb開頭的提示信息
-help(h) //命令行輔助信息
-se file //從file中讀取符號,并作為可執行文件
-core(c) file //指定core dump文件file
-c id //連接到進程號為id,與attach命令相似
-x file //file中存放一系列的gdb命令,執行file中的gdb命令
-symbols(s) //從file中讀取符號,但不作為可執行文件
-directory(d) path //指定路徑path,將path加入到搜索源文件的路徑中
注意:gdb開始運行時,它把任何一個不帶選項前綴的參數都當作一個可執行文件或core文件或進程號,具體為:把第一個前面沒有選項說明的參數看作加了-se選項,而第二個看作是跟著-c選項后面。在gdb中可以把選項名掐頭去尾,只要保證gdb能唯一判斷是哪個選項就行。
第三,逐步調試,部分命令如下:
break(b) [file:] func / line / addr / +num / -num //某函數、某行或者某內存地址處設斷點,可同時設置多個斷點
break args if COND //COND非零時在args處中斷
tbreak agrs //斷點只有效一次
clear [file:] func / line / addr / +num / -num //清楚某種斷點,可同時清除多個
delete(d) breaknum //使用斷點號來清除斷點或觀察點,沒有參數則清除所有斷點
disable(dis) breaknum //禁止……
enable [once] breaknum //啟用或者僅啟用一次……
--------------------------------
watch expr //expr值改變時停止程序,用于捕獲錯誤很有效
run(r) arg //從頭開始運行程序,并以arg作為參數(可多個)
continue(c) //繼續被中斷的程序,不能用作程序的運行啟動
step(s) //單步進入,跟蹤到函數內
next(n) //單步,不進入函數內
list(l) //顯示源代碼(正在執行區域附件10行)
backtrace(bt) / where(w) //顯示函數棧的內容
print(p) expr //查看變量或者表達式的值
display expr //每次中斷時,顯示expr的值
undisplay [expr] //取消display,沒有參數的話則取消全部
whatis expr //顯示expr的資料形態,例如變量類型等
------------------------------
set width 70 //設置屏幕列數
quit(q) //終止退出
kill(k) //終止正在調試的程序,但不退出調試,可重來
file //裝入想要調試的可執行文件
shell command //在gdb中直接運行shell命令且不需要退出gdb
help command //command命令說明
complete arg //列出所有arg開頭的命令
Esc + Shift + ? //查看所有命令的列表
------------------------------
attach pidat pid //接上一個執行的進程pid,這會使pid暫停,中斷任何sleep以及可中斷的系統調用
detach pid //解除目前接上的進程pid
jump address //跳到指定的內存位置,并開始執行
make filename //不退出gdb就能重新產生可執行文件
注意:
(1)有的命令后面可以跟參數,例如step接受一個參數表示單步執行多少步;有的命令不接受任何參數。
(2)空行表示重復上一個命令;有的命令不可重復,例如run;還有一些重復后會產生嚴重后果,建議不使用空行重復。
(3)可以使用gdb的info(i)和show命令來查詢程序狀態,每個命令可以查詢一系列的狀態,具體如下:
info:
info breakpoints //查看斷點情況
info args //查看程序參數
info display //查看所有display
info stack //查看函數棧內容,與backtrace相同
info watchpoints //查看觀察點
show:
show version //顯示gdb版本號
show copying //顯示版權信息
set:
set命令用來為程序設置運行環境,比如可以用set prompt $ 來把gdb提示符設置為$。使用set命令可以改變絕大多數show顯示的信息。
第四,調試完成后,可以使用strip命令刪除那些帶有-g選項的C編譯程序所生成的信息,釋放一些磁盤空間。
strip命令減少XCOFF對象文件的大小,strip命令從XCOFF對象文件中有選擇地除去行號信息、重定位信息、調試段、注釋段、文件頭以及所有或部分符號表。一旦使用該命令,則很難調試文件的符號,因此通常只在已經調試和測試過的生成模塊上使用strip命令。
/usr/binstrip [選項] file
strip的具體選項信息在這里不作總結。
gcc –o hello –g hello.c
其中-g的意思是生成帶源代碼調試符號的可執行文件hello,不使用-g進行編譯的可執行文件也可以使用gdb調試,但是缺少部分調試信息(如行號、函數名等)。調試信息包括用戶程序里的每個變量的類型和在可執行文件里的地址映射以及源代碼的行號。
第二,使用gdb hello進入gdb,進行調試階段。啟動gdb有以下幾種方式:












第三,逐步調試,部分命令如下:

































(1)有的命令后面可以跟參數,例如step接受一個參數表示單步執行多少步;有的命令不接受任何參數。
(2)空行表示重復上一個命令;有的命令不可重復,例如run;還有一些重復后會產生嚴重后果,建議不使用空行重復。
(3)可以使用gdb的info(i)和show命令來查詢程序狀態,每個命令可以查詢一系列的狀態,具體如下:
info:
info breakpoints //查看斷點情況
info args //查看程序參數
info display //查看所有display
info stack //查看函數棧內容,與backtrace相同
info watchpoints //查看觀察點
show:
show version //顯示gdb版本號
show copying //顯示版權信息
set:
set命令用來為程序設置運行環境,比如可以用set prompt $ 來把gdb提示符設置為$。使用set命令可以改變絕大多數show顯示的信息。
第四,調試完成后,可以使用strip命令刪除那些帶有-g選項的C編譯程序所生成的信息,釋放一些磁盤空間。
strip命令減少XCOFF對象文件的大小,strip命令從XCOFF對象文件中有選擇地除去行號信息、重定位信息、調試段、注釋段、文件頭以及所有或部分符號表。一旦使用該命令,則很難調試文件的符號,因此通常只在已經調試和測試過的生成模塊上使用strip命令。
/usr/binstrip [選項] file
strip的具體選項信息在這里不作總結。