調(diào)試,是開(kāi)發(fā)流程中一個(gè)非常重要的環(huán)節(jié)。每個(gè)程序員都應(yīng),具備調(diào)試代碼的能力,尤其對(duì)于從事 Linux 下的開(kāi)發(fā)的讀者。
從事 linux 下后臺(tái)開(kāi)發(fā),有時(shí)候會(huì)遇到程序突然崩潰的情況,也沒(méi)有任何日志,這會(huì)讓你不知所措。
今天給大家介紹一個(gè) core 文件,用這個(gè)文件,我們可以找出對(duì)應(yīng)出錯(cuò)的代碼行,感覺(jué)是不是很神奇。
什么是core dump
對(duì)于程序,由于各種異?;蛘?bug,導(dǎo)致在運(yùn)行過(guò)程中,并且在滿足一定條件下,產(chǎn)生一個(gè)叫做 core 的文件。
通常情況下,core 文件會(huì)包含了,程序運(yùn)行時(shí)的內(nèi)存,寄存器狀態(tài),堆棧指針,內(nèi)存管理信息還有各種函數(shù)調(diào)用堆棧信息等。
許多程序出錯(cuò)的時(shí)候,會(huì)產(chǎn)生一個(gè) core 文件。通過(guò)工具分析這個(gè)文件,我們可以定位到,程序異常退出的時(shí)候?qū)?yīng)的堆棧調(diào)用等信息。
打開(kāi) core dump 開(kāi)關(guān):ulimit -c unlimited
看一段有問(wèn)題的代碼:
#include< stdio.h >
int main()
{
int *p=NULL;
*p=0;
printf("badn");
return 0;
}
linux下編譯和執(zhí)行:
[root@VM-16-9-centos c++]# g++ -g main.cpp
[root@VM-16-9-centos c++]# ./a.out
Segmentation fault (core dumped)
[root@VM-16-9-centos c++]# ls
a.out core.1989 main.cpp
上述代碼一看就有錯(cuò)誤,執(zhí)行會(huì)產(chǎn)生 core dump。但是在大型項(xiàng)目中,用肉眼就很難看了。
-
Linux
+關(guān)注
關(guān)注
87文章
11511瀏覽量
213833 -
調(diào)試
+關(guān)注
關(guān)注
7文章
612瀏覽量
34731 -
文件
+關(guān)注
關(guān)注
1文章
579瀏覽量
25372 -
程序
+關(guān)注
關(guān)注
117文章
3826瀏覽量
82997
發(fā)布評(píng)論請(qǐng)先 登錄
解析汽車(chē)拋負(fù)載Load Dump:load dump產(chǎn)生原因與TVS并聯(lián)保護(hù)方案

ESP32_MINI燒錄程序后遇到esp_core_dump_flash問(wèn)題怎么解決?
多核ipc中斷的使用,請(qǐng)問(wèn)core1要發(fā)中斷,如何觸發(fā)?中斷服務(wù)程序是放在哪個(gè)core的工程里面?
關(guān)于系統(tǒng)應(yīng)用core dump的分析
sdk中編寫(xiě)的c程序是如何變成dump文件的?
你知道Linux Core Dump是什么?
學(xué)會(huì)用core dump調(diào)試程序錯(cuò)誤

段錯(cuò)誤調(diào)試神器 - Core Dump詳解
華為在中國(guó)市場(chǎng)測(cè)試HMS Core,用于取代Google移動(dòng)服務(wù)
linux中的core dump調(diào)試與運(yùn)用詳解
嵌入式Linux如何生成Core Dump文件

評(píng)論