在 Linux 下寫 C/C++ 程序的程序員,時常與 Core Dump 相見。在內存越界訪問,收到不能處理的信號,除零等錯誤出現時,我們精心或不精心寫就的程序就直接一命嗚呼了,Core Dump 是 Linux 仁慈地留下的程序的尸體,幫助程序員們解決了一個又一個問題。
有時配置不給力,Linux 直接毀尸滅跡,沒有了 Core 文件;又有時,剛好磁盤空間不足,Core文件寫不下了。沒有 Core 文件的時候,如何知道程序在什么地方出錯了呢?addr2line 就在這時派上用場。
這是一個示例程序,func 函數返回參數 a 除以參數 b 的結果。這里使用 0 作為除數,結果就是程序因為除以 0 導致錯誤,直接中斷了。
test.c
#include < stdio.h >
int func(int a, int b)
{
return a / b;
}
int main()
{
int x = 10;
int y = 0;
printf("%d / %d = %dn", x, y, func(x, y));
return 0;
}
編譯:-o 指定輸出文件名,-g 會有調試信息。
gcc -o test -g test.c
執行
./test
提示執行錯誤
輸入 dmesg 命令,查看 log,提示如下:
traps: test[2184] trap divide error ip:400534 sp:7ffee5779a90 error:0 in test[400000+1000]
ip 字段后面的數字就是 test 程序出錯時所程序執行的位置。使用 addr2line 就可以 將 400534 地址轉換出對應的文件及行數 :
可知,程序在執行到 test.c 文件第五行的時候,執行出錯,我們檢查第五行代碼。
return a / b;
這里除 0 肯定是不行的,addr2line 幫助我們找到了錯誤位置。
-
嵌入式
+關注
關注
5089文章
19167瀏覽量
306711 -
內存
+關注
關注
8文章
3043瀏覽量
74197 -
FreeRTOS
+關注
關注
12文章
484瀏覽量
62301 -
DEBUG
+關注
關注
3文章
94瀏覽量
19950
發布評論請先 登錄
相關推薦
評論