Linux除錯方法之core dump
阿新 • • 發佈:2018-12-28
目錄
最近面試的時候,被問到在linux下程式異常該怎麼除錯。經過學習才知道有core dump這種東西,隨手記錄。
core dump介紹
當程式執行的過程中異常終止或崩潰,作業系統會將程式當時的記憶體狀態記錄下來,儲存在一個檔案中,這種行為就叫做Core Dump(中文有的翻譯成“核心轉儲”)。我們可以認為 core dump 是“記憶體快照”,但實際上,除了記憶體資訊之外,還有些關鍵的程式執行狀態也會同時 dump 下來,例如暫存器資訊(包括程式指標、棧指標等)、記憶體管理資訊、其他處理器和作業系統狀態和資訊。core dump 對於程式設計人員診斷和除錯程式是非常有幫助的,因為對於有些程式錯誤是很難重現的,例如指標異常,而 core dump 檔案可以再現程式出錯時的情景。
0.測試程式如下
#include <stdio.h> int c() { *(char*)0=123; //0指標賦值會導致segmentation fault return 0; } int b(int num) { int a = num; char s[] = "hello world!"; printf("%s",s); c(); return 0; } int a() { int bbb =111; b(bbb); return 0; } int main(int argc,char *argv[]) { a(); return 0; }
1.開啟core dump
ulimit -c unlimited
2.輸出core dump
sudo echo "/tmp/corefile-%e-%p-%t" > /proc/sys/kernel/core_pattern
3.執行該檔案
gcc a.c -g
./a.out
此時執行之後,會在/tmp目錄下生成一個corefile-a.out-3151-1523451252
的core dump檔案
4.在終端輸出core dump
gdb ./a.out corefile-a.out-3151-1523451252
5.在gdb下輸入bt
bt
此時就可以看到呼叫棧,以及相關的出錯內容。