最近面試的時候,被問到在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
此時就可以看到調用棧,以及相關的出錯內容。