在 Linux 下寫 C/C++ 程序的程序員,時(shí)常與 Core Dump 相見。在內(nèi)存越界訪問,收到不能處理的信號(hào),除零等錯(cuò)誤出現(xiàn)時(shí),我們精心或不精心寫就的程序就直接一命嗚呼了,Core Dump 是 Linux 仁慈地留下的程序的尸體,幫助程序員們解決了一個(gè)又一個(gè)問題。
有時(shí)配置不給力,Linux 直接毀尸滅跡,沒有了 Core 文件;又有時(shí),剛好磁盤空間不足,Core文件寫不下了。沒有 Core 文件的時(shí)候,如何知道程序在什么地方出錯(cuò)了呢?addr2line 就在這時(shí)派上用場(chǎng)。
這是一個(gè)示例程序,func 函數(shù)返回參數(shù) a 除以參數(shù) b 的結(jié)果。這里使用 0 作為除數(shù),結(jié)果就是程序因?yàn)槌?0 導(dǎo)致錯(cuò)誤,直接中斷了。
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 會(huì)有調(diào)試信息。
gcc -o test -g test.c
執(zhí)行
./test
提示執(zhí)行錯(cuò)誤
輸入 dmesg 命令,查看 log,提示如下:
traps: test[2184] trap divide error ip:400534 sp:7ffee5779a90 error:0 in test[400000+1000]
ip 字段后面的數(shù)字就是 test 程序出錯(cuò)時(shí)所程序執(zhí)行的位置。使用 addr2line 就可以 將 400534 地址轉(zhuǎn)換出對(duì)應(yīng)的文件及行數(shù) :
可知,程序在執(zhí)行到 test.c 文件第五行的時(shí)候,執(zhí)行出錯(cuò),我們檢查第五行代碼。
return a / b;
這里除 0 肯定是不行的,addr2line 幫助我們找到了錯(cuò)誤位置。
-
嵌入式
+關(guān)注
關(guān)注
5149文章
19655瀏覽量
317316 -
內(nèi)存
+關(guān)注
關(guān)注
8文章
3121瀏覽量
75241 -
FreeRTOS
+關(guān)注
關(guān)注
12文章
492瀏覽量
64297 -
DEBUG
+關(guān)注
關(guān)注
3文章
94瀏覽量
20533
發(fā)布評(píng)論請(qǐng)先 登錄
在wsl2中安裝的idf,在monitor時(shí)會(huì)報(bào)錯(cuò)的原因?
調(diào)用rt_timer_check函數(shù)就報(bào)錯(cuò),為什么?
藍(lán)牙模塊HC-05中l(wèi)inelen=get_line(linebuff,redata+getlen+2*linenum,len);為什么linenum要*2
如何在開發(fā)板子上安裝addr2line工具?
C語言在ARM中函數(shù)調(diào)用時(shí)棧變化的過程
一步步介紹CmBacktrace的相關(guān)知識(shí)和使用方法
在wsl2中安裝的idf,在monitor報(bào)錯(cuò)的原因?如何解決?
當(dāng)On Line Debug時(shí),會(huì)無緣無故的離線是為什么?
NCV8402ADDR2G雙路MOS管的特性及應(yīng)用
如何用示波器去測(cè)量脈沖信號(hào)呢
C語言在ARM中函數(shù)調(diào)用時(shí),棧是如何變化的?

NCV8402ADDR2G,原裝正品,價(jià)格美麗

Linux中addr2line用法介紹
linux下調(diào)試core dump的方法
RVBacktrace RISC-V極簡棧回溯組件

評(píng)論