當代碼量較多時,使用GDB調試代碼可以相對便捷的定位錯誤點,提高Dbug效率。
首先先熟悉下GDB調試的基本流程:
1. 在編譯代碼是添加 gcc添加–g選項
:gcc -g test.c -o test.out
2. 然後在bash環境中使用GDB 指令調用編譯生成程式:
:gdb ./test.out
進入調試頁面
在這個界面下我們可以通過一些GDB的常用指令進行代碼的細節調試,常用指令如下:
運作該程式:run(簡寫r)
檢視代碼:list(簡寫l)
打斷點:break(簡寫b)後跟行号(或者函數名、檔案名:行号)
檢視所有斷點:info break
跳轉到下一斷點處:continue(簡寫c)
删除斷點:delete(簡寫d)斷點編号
單步執行:next(簡寫n)
進入函數:step(簡寫s)
檢視變量的值:print(簡寫p)變量名(隻顯示一次)
檢視變量的值,并且使其動态改變:display 變量名(一直顯示,并且動态變化)
删除10中變量的顯示:undisplay 變量号(非變量名)
跳到某行:until 行号(中途有斷點則暫停到斷點處)
檢視調用堆棧:bt
執行完目前的函數:finish
設定變量的值:set var 變量名 = 值
關閉斷點:disable 斷點号
開啟斷點:enable 斷點号
執行上一次的指令:Enter按鍵
退出gdb:quit(簡寫q)
首先我們可以使用list顯示目前程式入口代碼:
在調試的關鍵點上使用break指令添加斷點,并是可以使用info break檢視斷點:
添加斷點後可以使用run指令開始運作程式,程式将運作至第一個斷點處:
程式運作後使用 print 指令檢視目前的變量值
使用 next 指令可以進行單步調試,每次執行一行,同樣可以使用print 指令檢視變量變化
如果需要重複關注變量值,可以使用display指令這樣每次執行暫停後都會自動顯示變量值
如果想停止調試,可以執行quit指令退出調試界面。
其他指令大家可以自行嘗試,比如continue可以直接從目前位置直接執行到下一個斷點處,使用的頻率也比較高,這裡不在複述。--孟德慧。
在日常調試中,我們經常會遇到段錯誤。使用gdb可以可以很容易的找到錯誤的根源。
首先,重新使用–g選項編譯出錯代碼。并正常運作直至其出段錯誤。測試代碼如下:
段錯誤觸發後,同目錄下回生成一個core檔案,裡面儲存的是段錯誤相關資訊。如果core檔案沒有生成,則是因為系統預設core檔案大小為0,可以運作ulimit -c 10000來設定core檔案容量,然後重新執行程式。
得到core檔案後,使用gdb./test core 來檢視出錯代碼所在位置。
并可以執行run指令在gdb調試界面下直接運作程式,使段錯誤再次出現。
之後執行 pirnt指令來檢視出錯行相關數值來确認錯誤資訊:确定*p為空指針操作(實際代碼中更多的可能是野指針或越界操作)。
嵌入式物聯網需要學的東西真的非常多,千萬不要學錯了路線和内容,導緻工資要不上去!
無償分享大家一個資料包,差不多150多G。裡面學習内容、面經、項目都比較新也比較全!某魚上買估計至少要好幾十。
點選這裡找小助理0元領取:加微信領取資料