調(diào)試,是開發(fā)流程中一個非常重要的環(huán)節(jié)。每個程序員都應(yīng),具備調(diào)試代碼的能力,尤其對于從事 Linux 下的開發(fā)的讀者。
從事 linux 下后臺開發(fā),有時候會遇到程序突然崩潰的情況,也沒有任何日志,這會讓你不知所措。
今天給大家介紹一個 core 文件,用這個文件,我們可以找出對應(yīng)出錯的代碼行,感覺是不是很神奇。
什么是core dump
對于程序,由于各種異常或者 bug,導(dǎo)致在運行過程中,并且在滿足一定條件下,產(chǎn)生一個叫做 core 的文件。
通常情況下,core 文件會包含了,程序運行時的內(nèi)存,寄存器狀態(tài),堆棧指針,內(nèi)存管理信息還有各種函數(shù)調(diào)用堆棧信息等。
許多程序出錯的時候,會產(chǎn)生一個 core 文件。通過工具分析這個文件,我們可以定位到,程序異常退出的時候?qū)?yīng)的堆棧調(diào)用等信息。
打開 core dump 開關(guān):ulimit -c unlimited
看一段有問題的代碼:
#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
上述代碼一看就有錯誤,執(zhí)行會產(chǎn)生 core dump。但是在大型項目中,用肉眼就很難看了。
-
Linux
+關(guān)注
關(guān)注
87文章
11329瀏覽量
209967 -
調(diào)試
+關(guān)注
關(guān)注
7文章
586瀏覽量
34000 -
文件
+關(guān)注
關(guān)注
1文章
569瀏覽量
24777 -
程序
+關(guān)注
關(guān)注
117文章
3793瀏覽量
81223
發(fā)布評論請先 登錄
相關(guān)推薦
ESP32_MINI燒錄程序后遇到esp_core_dump_flash問題怎么解決?
多核ipc中斷的使用,請問core1要發(fā)中斷,如何觸發(fā)?中斷服務(wù)程序是放在哪個core的工程里面?
關(guān)于系統(tǒng)應(yīng)用core dump的分析
sdk中編寫的c程序是如何變成dump文件的?
你知道Linux Core Dump是什么?
學(xué)會用core dump調(diào)試程序錯誤
![學(xué)會用<b class='flag-5'>core</b> <b class='flag-5'>dump</b>調(diào)試<b class='flag-5'>程序</b>錯誤](https://file.elecfans.com/web1/M00/92/57/pIYBAFzdItmARFSlAAAcmaqFX_w453.png)
段錯誤調(diào)試神器 - Core Dump詳解
華為在中國市場測試HMS Core,用于取代Google移動服務(wù)
linux中的core dump調(diào)試與運用詳解
嵌入式Linux如何生成Core Dump文件
![嵌入式Linux如何生成<b class='flag-5'>Core</b> <b class='flag-5'>Dump</b>文件](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
評論