一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

在程序中什么是core dump

麥辣雞腿堡 ? 來(lái)源:盼盼編程 ? 作者:晨夢(mèng)思雨 ? 2023-10-08 16:07 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

調(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)目中,用肉眼就很難看了。

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 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
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    解析汽車(chē)拋負(fù)載Load Dump:load dump產(chǎn)生原因與TVS并聯(lián)保護(hù)方案

    讓我們聊聊Load Dump 汽車(chē)電子,load dump指的是低壓電池充電時(shí)與車(chē)輛的發(fā)電機(jī)突然斷開(kāi)連接。由于電池的突然斷開(kāi),其余被接
    的頭像 發(fā)表于 01-24 10:43 ?5946次閱讀
    解析汽車(chē)拋負(fù)載Load <b class='flag-5'>Dump</b>:load <b class='flag-5'>dump</b>產(chǎn)生原因與TVS并聯(lián)保護(hù)方案

    ESP32_MINI燒錄程序后遇到esp_core_dump_flash問(wèn)題怎么解決?

    ) esp_core_dump_flash: Core dump flash config is corrupted! CRC=0x7bd5c66f instead of 0x0 Rebooting... ets
    發(fā)表于 07-01 06:52

    多核ipc中斷的使用,請(qǐng)問(wèn)core1要發(fā)中斷,如何觸發(fā)?中斷服務(wù)程序是放在哪個(gè)core的工程里面?

    本帖最后由 一只耳朵怪 于 2018-6-19 15:27 編輯 c6657core1通過(guò)外設(shè)接收新的數(shù)據(jù),core1來(lái)做信號(hào)處理;處理的結(jié)果再在
    發(fā)表于 06-19 07:49

    關(guān)于系統(tǒng)應(yīng)用core dump的分析

    解決段錯(cuò)誤,系統(tǒng)應(yīng)用core dump的分析 這個(gè)錯(cuò)誤單片機(jī)上往往以hardfault的錯(cuò)誤出現(xiàn),分析思路都是分析堆棧的位置;單片機(jī)的編譯軟件,如果可以仿真(比如keil或者IAR),復(fù)現(xiàn)故障
    發(fā)表于 03-02 06:10

    sdk編寫(xiě)的c程序是如何變成dump文件的?

    各位前輩,sdk編寫(xiě)的c程序是如何變成dump文件的,他的轉(zhuǎn)換過(guò)程大概是什么,還有就是轉(zhuǎn)化后的dump文件的main部分為啥
    發(fā)表于 08-11 07:21

    你知道Linux Core Dump是什么?

    當(dāng)程序運(yùn)行的過(guò)程異常終止或崩潰,操作系統(tǒng)會(huì)將程序當(dāng)時(shí)的內(nèi)存狀態(tài)記錄下來(lái),保存在一個(gè)文件,這種行為就叫做Core
    發(fā)表于 05-10 11:11 ?3049次閱讀

    學(xué)會(huì)用core dump調(diào)試程序錯(cuò)誤

    . 嵌入式系統(tǒng),有時(shí)core dump直接從串口打印出來(lái),結(jié)合objdump查找ra和epa地址,運(yùn)用?;厮荩梢哉业?b class='flag-5'>程序出錯(cuò)的地方。
    發(fā)表于 05-16 16:44 ?1437次閱讀
    學(xué)會(huì)用<b class='flag-5'>core</b> <b class='flag-5'>dump</b>調(diào)試<b class='flag-5'>程序</b>錯(cuò)誤

    段錯(cuò)誤調(diào)試神器 - Core Dump詳解

    core大小為無(wú)限.?用gdb查看core文件: 下面我們可以發(fā)生運(yùn)行時(shí)信號(hào)引起的錯(cuò)誤時(shí)發(fā)生core dump了. 發(fā)生
    發(fā)表于 04-02 14:34 ?1485次閱讀

    華為中國(guó)市場(chǎng)測(cè)試HMS Core,用于取代Google移動(dòng)服務(wù)

    華為已經(jīng)中國(guó)市場(chǎng)測(cè)試HMS Core框架和HMS core應(yīng)用程序,以取代Google移動(dòng)服務(wù)(GMS)應(yīng)用程序。很快,通過(guò)替換華為移動(dòng)服
    的頭像 發(fā)表于 02-24 16:24 ?4594次閱讀

    虛擬機(jī):Linux設(shè)置core dump文件名的格式

    虛擬機(jī):Linux設(shè)置core dump文件名的格式
    的頭像 發(fā)表于 06-22 17:50 ?3171次閱讀
    虛擬機(jī):Linux設(shè)置<b class='flag-5'>core</b> <b class='flag-5'>dump</b>文件名的格式

    linuxcore dump調(diào)試與運(yùn)用詳解

    調(diào)試,是開(kāi)發(fā)流程中一個(gè)非常重要的環(huán)節(jié)。每個(gè)程序員都應(yīng),具備調(diào)試代碼的能力,尤其對(duì)于從事 Linux 下的開(kāi)發(fā)的讀者。
    的頭像 發(fā)表于 04-12 14:24 ?2384次閱讀

    嵌入式Linux如何生成Core Dump文件

    運(yùn)行,二者有何區(qū)別 前臺(tái)運(yùn)行和后臺(tái)運(yùn)行的區(qū)別 前后臺(tái)程序生成core dump時(shí)有何區(qū)別 前臺(tái)進(jìn)程如何生成core dump 后臺(tái)進(jìn)
    發(fā)表于 11-01 17:21 ?17次下載
    嵌入式Linux如何生成<b class='flag-5'>Core</b> <b class='flag-5'>Dump</b>文件

    linux下調(diào)試core dump的方法

    下面說(shuō)明一下 linux 下調(diào)試 core dump 方法。 dmesg+addr2line調(diào)試 先介紹 2 個(gè) linux 命令: dmesg ,一種程序,用于檢測(cè)和控制內(nèi)核緩沖。程序
    的頭像 發(fā)表于 10-08 16:13 ?875次閱讀

    jmap dump內(nèi)存的命令是

    jmap dump是Java內(nèi)存映像工具(Java Memory Map Tool)的一個(gè)功能,用于生成Java虛擬機(jī)(JVM)的堆內(nèi)存快照。堆內(nèi)存快照是一個(gè)包含了Java對(duì)象及其所占用內(nèi)存空間
    的頭像 發(fā)表于 12-05 10:38 ?3648次閱讀

    jvm的dump太大了怎么分析

    分析大型JVM dump文件可能會(huì)遇到的一些挑戰(zhàn)。首先,JVM dump文件通常非常大,可能幾百M(fèi)B或幾個(gè)GB。這是因?yàn)樗鼈儼薐VM的完整內(nèi)存快照,包括堆和棧的所有對(duì)象和線程信息。分析這種大型
    的頭像 發(fā)表于 12-05 11:01 ?3482次閱讀