首先說明一點,如果我們要使用gdb來除錯我們的c/c++程式時,在使用gcc編譯程式時,應該帶上 –g 引數, 它負責生成 與gdb相關的除錯資訊;
方法一: 命令列輸入: gdb filename方法二: 命令列輸入: gdb , 進行gdb工作介面以後,再輸入命令: file filename ,其中file為gdb的乙個命令;
命令解釋
示例
file 《檔名》
載入被除錯的可執行程式檔案。
因為一般都在被除錯程式所在目錄下執行gdb,因而文字名不需要帶路徑。
(gdb) file gdb-sample
r run的簡寫,執行被除錯的程式。
如果此前沒有下過斷點,則執行完整個程式;如果有斷點,則程式暫停在第乙個可用斷點處。
(gdb) r
c continue的簡寫,繼續執行被除錯程式,直至下乙個斷點或程式結束。
(gdb) c
b 《行號》
b 《函式名稱》
b *《函式名稱》
b *《**位址》
d [編號]
b: breakpoint的簡寫,設定斷點。兩可以使用「行號」「函式名稱」「執行位址」等方式指定斷點位置。
其中在函式名稱前面加「*」符號表示將斷點設定在「由編譯器生成的prolog**處」。如果不了解彙編,可以不予理會此用法。
d: delete breakpoint的簡寫,刪除指定編號的某個斷點,或刪除所有斷點。斷點編號從1開始遞增。
(gdb) b 8
(gdb) b main
(gdb) b *main
(gdb) b *0x804835c
(gdb) d
s, n
s: 執行一行源程式**,如果此行**中有函式呼叫,則進入該函式;
n: 執行一行源程式**,此行**中的函式呼叫也一併執行。
s 相當於其它偵錯程式中的「step into (單步跟蹤進入)」;
n 相當於其它偵錯程式中的「step over (單步跟蹤)」。
這兩個命令必須在有源**除錯資訊的情況下才可以使用(gcc編譯時使用「-g」引數)。
(gdb) s
(gdb) n
si, ni
si命令類似於s命令,ni命令類似於n命令。所不同的是,這兩個命令(si/ni)所針對的是彙編指令,而s/n針對的是源**。
(gdb) si
(gdb) ni
p 《變數名稱》
print的簡寫,顯示指定變數(臨時變數或全域性變數)的值。
(gdb) p i
(gdb) p nglobalvar
display ...
undisplay 《編號》
display,設定程式中斷後欲顯示的資料及其格式。
例如,如果希望每次程式中斷後可以看到即將被執行的下一條彙編指令,可以使用命令
「display /i $pc」
其中 $pc 代表當前彙編指令,/i 表示以十六進行顯示。當需要關心彙編**時,此命令相當有用。
undispaly,取消先前的display設定,編號從1開始遞增。
(gdb) display /i $pc
(gdb) undisplay 1
i info的簡寫,用於顯示各類資訊,詳情請查閱「help i」。
(gdb) i r
q quit的簡寫,退出gdb除錯環境。
(gdb) q
help [命令名稱]
gdb幫助命令,提供對gdb名種命令的解釋說明。
如果指定了「命令名稱」引數,則顯示該命令的詳細說明;如果沒有指定引數,則分類顯示所有gdb命令,供使用者進一步瀏覽和查詢。
(gdb) help display
(來自:總結不錯,請大家檢視原出處;)
嗯,好,行;
GDB常用除錯命令
呼叫gdb編譯需要在cc後面加 g引數再加 o root redhat home gdb 除錯檔案 啟動gdb gdb l 字母l 從第一行開始列出原始碼 gdb break n 在第n行處設定斷點 gdb break func 在函式func 的入口處設定斷點 gdb info break 檢視斷...
gdb常用除錯命令
將.c檔案程式設計成包含標準除錯資訊的檔案 命令 gcc g c o 1 啟動gdb除錯程式 兩種方式 a gdb filename b 啟動gdb後,使用file filename 2 list l 檢視程式 方便設定斷點 3 break b 函式名 在某函式入口處新增斷點 4 break 行號 ...
GDB 常用除錯命令
呼叫gdb編譯需要在cc後面加 g引數再加 o root redhat home gdb 除錯檔案 啟動gdb gdb l 字母l 從第一行開始列出原始碼 gdb break n 在第n行處設定斷點 gdb break func 在函式func 的入口處設定斷點 gdb info break 檢視斷...