調(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。但是在大型項目中,用肉眼就很難看了。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
相關(guān)推薦
) esp_core_dump_flash: Core dump flash config is corrupted! CRC=0x7bd5c66f instead of 0x0
Rebooting...
ets
發(fā)表于 07-01 06:52
本帖最后由 一只耳朵怪 于 2018-6-19 15:27 編輯
c6657core1通過外設(shè)接收新的數(shù)據(jù),在core1中來做信號處理;處理的結(jié)果再在
發(fā)表于 06-19 07:49
解決段錯誤,系統(tǒng)應(yīng)用core dump的分析 這個錯誤在單片機上往往以hardfault的錯誤出現(xiàn),分析思路都是分析堆棧的位置;單片機的編譯軟件,如果可以仿真(比如keil或者IAR),復(fù)現(xiàn)故障
發(fā)表于 03-02 06:10
各位前輩,sdk中編寫的c程序是如何變成dump文件的,他的轉(zhuǎn)換過程大概是什么,還有就是轉(zhuǎn)化后的dump文件中的main部分為啥
發(fā)表于 08-11 07:21
當(dāng)程序運行的過程中異常終止或崩潰,操作系統(tǒng)會將程序當(dāng)時的內(nèi)存狀態(tài)記錄下來,保存在一個文件中,這種行為就叫做Core
發(fā)表于 05-10 11:11
?2845次閱讀
. 在嵌入式系統(tǒng)中,有時core dump直接從串口打印出來,結(jié)合objdump查找ra和epa地址,運用棧回溯,可以找到程序出錯的地方。
發(fā)表于 05-16 16:44
?1312次閱讀
core大小為無限.?用gdb查看core文件: 下面我們可以在發(fā)生運行時信號引起的錯誤時發(fā)生core dump了. 發(fā)生
發(fā)表于 04-02 14:34
?1183次閱讀
華為已經(jīng)在中國市場測試HMS Core框架和HMS core應(yīng)用程序,以取代Google移動服務(wù)(GMS)應(yīng)用程序。很快,通過替換華為移動服
發(fā)表于 02-24 16:24
?4373次閱讀
虛擬機:Linux設(shè)置core dump文件名的格式
發(fā)表于 06-22 17:50
?2959次閱讀
調(diào)試,是開發(fā)流程中一個非常重要的環(huán)節(jié)。每個程序員都應(yīng),具備調(diào)試代碼的能力,尤其對于從事 Linux 下的開發(fā)的讀者。
發(fā)表于 04-12 14:24
?2150次閱讀
運行,二者有何區(qū)別 前臺運行和后臺運行的區(qū)別 前后臺程序生成core dump時有何區(qū)別 前臺進(jìn)程如何生成core dump 后臺進(jìn)
發(fā)表于 11-01 17:21
?17次下載
當(dāng)程序運行的過程中異常終止或崩潰,操作系統(tǒng)會將程序當(dāng)時的內(nèi)存狀態(tài)記錄下來,保存在一個文件中,這種行為就叫做 Core
發(fā)表于 02-17 15:57
?640次閱讀
下面說明一下 linux 下調(diào)試 core dump 方法。 dmesg+addr2line調(diào)試 先介紹 2 個 linux 命令: dmesg ,一種程序,用于檢測和控制內(nèi)核緩沖。程序
發(fā)表于 10-08 16:13
?655次閱讀
jmap dump是Java內(nèi)存映像工具(Java Memory Map Tool)的一個功能,用于生成Java虛擬機(JVM)中的堆內(nèi)存快照。堆內(nèi)存快照是一個包含了Java對象及其所占用內(nèi)存空間
發(fā)表于 12-05 10:38
?3201次閱讀
分析大型JVM dump文件可能會遇到的一些挑戰(zhàn)。首先,JVM dump文件通常非常大,可能幾百MB或幾個GB。這是因為它們包含了JVM的完整內(nèi)存快照,包括堆和棧的所有對象和線程信息。分析這種大型
發(fā)表于 12-05 11:01
?2776次閱讀
評論