在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

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

麥辣雞腿堡 ? 來源:盼盼編程 ? 作者:晨夢思雨 ? 2023-10-08 16:13 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

下面說明一下 linux 下調(diào)試 core dump 方法。

dmesg+addr2line調(diào)試

先介紹 2 個 linux 命令:

dmesg ,一種程序,用于檢測和控制內(nèi)核緩沖。程序用來幫助用戶,了解系統(tǒng)的啟動信息,可以獲得出錯堆棧地址。

addr2line ,可以將指令的地址和可執(zhí)行映像轉(zhuǎn)換成文件名,函數(shù)名或源代碼的工具。這種功能將跟蹤地址轉(zhuǎn)換成更有意義的內(nèi)容來說很有用。

在調(diào)用 addr2line 工具時,要使用 -e 選項來指定可執(zhí)行映像,使用 -f 選項可以告訴工具輸出函數(shù)名。

linux下操作過程:

[root@VM-16-9-centos c++]# dmesg | grep a.out 
[  212.330289] a.out[1946]: segfault at 0 ip 0000000000400571 sp 00007ffdf0aafbb0 error 6 in a.out[400000+1000]
[  227.437065] a.out[1989]: segfault at 0 ip 0000000000400571 sp 00007ffcfd01c8c0 error 6 in a.out[400000+1000]
[root@VM-16-9-centos c++]# 
[root@VM-16-9-centos c++]# addr2line -e a.out 0000000000400571
/root/c++/main.cpp:6

先通過dmesg找到對應(yīng)出錯的地址,再用 addr2line -e 將地址解析到對應(yīng)的代碼行。

gdb調(diào)試

gdb 想必大家都有聽說,Linux 下面一款常用的的調(diào)試工具。
gdb 編譯器通常以 gdb 命令的形式在終端中使用,下面學(xué)習(xí)下常用調(diào)試選項。

bt :查看堆棧信息

i locals :查看當(dāng)前程序棧的局部變量

i args :查看當(dāng)前程序棧的參數(shù)

i catch :查看當(dāng)前程序中棧幀的異常處理器

p a :打印變量的值

i register :查看當(dāng)前寄存器的值

r :從運行程序至第一個斷點,沒有斷點則一直運行完

quit :退出

gdb調(diào)試過程中,輸入 r ,bt。r 是運行 a.out 文件,bt查看堆棧情況。
我們不需要執(zhí)行 gdb a.out,這樣就相當(dāng)于重新運行了 a.out 文件。然而在實際開發(fā)中,有很多問題都是概率發(fā)生的,所以此方法不太實用。

linux下操作過程(省略部分 gdb 介紹信息):

[root@VM-16-9-centos c++]# gdb a.out core.1989 
Reading symbols from /root/c++/a.out...done.
[New LWP 1989]
bCore was generated by `./a.out'.
Program terminated with signal 11, Segmentation fault.
#0  0x0000000000400571 in main () at main.cpp:6
6        *p=0;
Missing separate debuginfos, use: debuginfo-install glibc-2.17-307.el7.1.x86_64 libgcc-4.8.5-44.el7.x86_64 libstdc++-4.8.5-44.el7.x86_64
(gdb) bt
#0  0x0000000000400571 in main () at main.cpp:6
(gdb)

直接執(zhí)行 gdb a.out core.1989,不用 r 命令避免程序重復(fù)執(zhí)行。使用 bt 命令,可以看到程序出錯代碼行。

strace+addr2line調(diào)試

strace 是一個集診斷、調(diào)試、統(tǒng)計與一體的工具,我們可以使用strace,對應(yīng)用的系統(tǒng)調(diào)用和信號傳遞的跟蹤結(jié)果,來對應(yīng)用進行分析,以達到解決問題,或者是了解應(yīng)用工作過程的目的。

strace 的簡單的用法就是,執(zhí)行一個指定的命令,在指定的命令結(jié)束之后,它也就退出了。
在命令執(zhí)行的過程中,strace 會記錄和解析命令進程的所有系統(tǒng)調(diào)用,以及這個進程所接收到的,所有的信號值。

-c ,統(tǒng)計每一系統(tǒng)調(diào)用的所執(zhí)行的時間,次數(shù)和出錯的次數(shù)等

-p ,指定進程pid
-i ,輸出系統(tǒng)調(diào)用的入口指針

linux 下操作過程(省略部分加載信息):

[root@VM-16-9-centos c++]# strace -i ./a.out 
[00007f79d3573847] munmap(0x7f79d3772000, 31038) = 0
[0000000000400571] --- SIGSEGV {si_signo=SIGSEGV, si_code=SEGV_MAPERR, si_addr=NULL} ---
[????????????????] +++ killed by SIGSEGV (core dumped) +++
Segmentation fault
[root@VM-16-9-centos c++]# addr2line -e a.out 0000000000400571
/root/c++/main.cpp:6
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11506

    瀏覽量

    213481
  • 調(diào)試
    +關(guān)注

    關(guān)注

    7

    文章

    612

    瀏覽量

    34666
  • 程序
    +關(guān)注

    關(guān)注

    117

    文章

    3826

    瀏覽量

    82819
  • 系統(tǒng)
    +關(guān)注

    關(guān)注

    1

    文章

    1032

    瀏覽量

    21800
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

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

    ESP32_MINI燒錄程序后遇到esp_core_dump_flash問題怎么解決?

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

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

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

    你知道Linux Core Dump是什么?

    當(dāng)程序運行的過程中異常終止或崩潰,操作系統(tǒng)會將程序當(dāng)時的內(nèi)存狀態(tài)記錄下來,保存在一個文件中,這種行為就叫做Core Dump(中文有的翻譯成“核心轉(zhuǎn)儲”)。
    發(fā)表于 05-10 11:11 ?3040次閱讀

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

    . 在嵌入式系統(tǒng)中,有時core dump直接從串口打印出來,結(jié)合objdump查找ra和epa地址,運用棧回溯,可以找到程序出錯的地方。
    發(fā)表于 05-16 16:44 ?1433次閱讀
    學(xué)會用<b class='flag-5'>core</b> <b class='flag-5'>dump</b><b class='flag-5'>調(diào)試</b>程序錯誤

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

    地址。通過系統(tǒng)服務(wù)啟動的進程也可通過這一方法查看。 9. 嵌入式設(shè)備下如何使用Core dump: linux coredump配置與調(diào)試
    發(fā)表于 04-02 14:34 ?1471次閱讀

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

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

    linux中的core dump調(diào)試與運用詳解

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

    使用 VSCode 遠程 圖形化 GDB 調(diào)試 嵌入式linux

    目錄標(biāo)題引言環(huán)境步驟vscode remote ssh 配置Linux編譯機配置設(shè)備板端配置vscode launch設(shè)置調(diào)試引言之前說了,通過core dump找程序bug,但是有
    發(fā)表于 11-01 17:06 ?1次下載
    使用 VSCode 遠程 圖形化 GDB <b class='flag-5'>調(diào)試</b> 嵌入式<b class='flag-5'>linux</b>

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

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

    Core 1808 JD4資源linux header/linux image

    電子發(fā)燒友網(wǎng)站提供《Core 1808 JD4資源linux header/linux image.txt》資料免費下載
    發(fā)表于 09-20 16:58 ?10次下載
    <b class='flag-5'>Core</b> 1808 JD4資源<b class='flag-5'>linux</b> header/<b class='flag-5'>linux</b> image

    hypervisor的調(diào)試分析方法

    我們在編寫裸機程序(baremetal)、虛擬化管理程序(hypervisor)和操作系統(tǒng)(OS)時,Debug分析程序是必不可少的。不像linux內(nèi)核,有大量的調(diào)試方法,很多裸機程序、hypervisor沒有完善的
    的頭像 發(fā)表于 10-08 09:40 ?1742次閱讀

    使用gdb對core文件進行調(diào)試

    Linux下,一個程序崩潰時,它一般會在指定目錄下生成一個core文件。core文件僅僅是一個內(nèi)存映象(同時加上調(diào)試信息),主要是用來調(diào)試
    的頭像 發(fā)表于 10-26 11:12 ?9495次閱讀

    VCD/FSDB/SHM/VPD波形dump方法

    仿真是IC設(shè)計不可或缺的重要步聚,其中仿真波形是debug的必要條件。今天簡要介紹下一下幾種波形文件VCD/FSDB /SHM/VPD的dump方法
    的頭像 發(fā)表于 11-11 09:36 ?1.8w次閱讀

    在程序中什么是core dump

    調(diào)試,是開發(fā)流程中一個非常重要的環(huán)節(jié)。每個程序員都應(yīng),具備調(diào)試代碼的能力,尤其對于從事 Linux 下的開發(fā)的讀者。 從事 linux 下后臺開發(fā),有時候會遇到程序突然崩潰的情況,也沒
    的頭像 發(fā)表于 10-08 16:07 ?1202次閱讀

    jvm的dump太大了怎么分析

    文件需要耗費大量的時間和計算資源。 然而,這并不意味著我們無法分析和利用JVM dump文件。以下是一些方法和技巧,可幫助我們有效地分析大型JVM dump文件。 使用工具:首先,我們可以使用一些專門用于分析JVM
    的頭像 發(fā)表于 12-05 11:01 ?3432次閱讀
    主站蜘蛛池模板: 55夜色66夜色国产精品站 | 思思久久96热在精品不卡 | 另类专区欧美 | 欧美日韩色综合网站 | 天堂网在线.www天堂在线资源 | 最好看的最新中文字幕2018免费视频 | 三级视频中文字幕 | 亚洲视频二 | 天天干天天在线 | 天堂网2018| 天天做爽夜夜做爽 | 欧美综合天天夜夜久久 | 依人成人 | 天天操天天干天天玩 | 免费看一级特黄a大片 | 在线天堂中文在线资源网 | 欧美猛操 | 亚洲一区二区三区不卡视频 | 22sihu国产精品视频影视资讯 | 六月婷婷色 | 国产在线视欧美亚综合 | a视频免费看 | 中文天堂最新版资源新版天堂资源 | 久久影院午夜伦手机不四虎卡 | 亚洲欧洲一区二区三区在线观看 | 国产女人和拘做受视频免费 | 老师喂我吃她的奶水脱她胸罩 | 人人九九精 | 国产精品成人一区二区 | 亚洲第一视频网 | 黑色丝袜美美女被躁视频 | 欧美色综合高清免费 | 经典三级一区在线播放 | jlzzjlzz欧美大全| 日韩午夜r电影在线观看 | 香蕉视频在线观看国产 | 亚洲高清免费视频 | 欧美黄色影院 | 九九re热 | 色综合88 | 婷婷综合网站 |