前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Linux】Coredump调试

【Linux】Coredump调试

作者头像
半生瓜的blog
发布2023-05-13 14:10:17
3K0
发布2023-05-13 14:10:17
举报
文章被收录于专栏:半生瓜のblog

Coredump 调试

Coredump是什么?

Linux环境下,当程序异常退出(发生段错误)时,会产生一个core文件,该文件记录了程序运行时的内存,寄存器状态,堆栈指针,内存管理信息还有各种函数调用堆栈信息等,我们可以理解为是程序工作当前状态存储生成的一个文件,通过工具分析这个文件,我们可以定位到程序异常退出的时候对应的堆栈调用等信息,找出问题所在并进行及时解决。


前期设置

  1. 设置core文件生成的目录,其中%e表示程序文件名,%p表示进程ID,否则会在程序的当前目录生成dore文件。
代码语言:javascript
复制
echo /home/xuanxuan/data/coredump/core.%e.%p >/proc/sys/kernel/core_pattern

  1. 当前执行程序的用户对core目录有写权限且右足够的空间存储core文件。

  1. 生成不受限制的core文件。
代码语言:javascript
复制
ulimit  -c unlimited 

什么情况下会导致程序异常退出?

非法指针的访问,堆栈溢出。


如何调试

  1. 编译的时候添加-g选项,增加调试信息。
  2. gdb program core_file

**示例:**一个会产生异常退出的程序,非法指针访问。demo.c

代码语言:javascript
复制
#include <stdio.h>
int func(int* p){
    int y = *p;
    return y;
}
int main(void){
    int *p = NULL;
    return func(p);
}

编译,运行,错误已产生。如下图所示。

image-20220712201015128
image-20220712201015128

执行调试命令,结果如下图所示。

代码语言:javascript
复制
gdb demo /home/xuanxuan/data/coredump/core.demo.3102
image-20220712201516630
image-20220712201516630

bt/where命令查看堆栈调用信息

image-20220712202258418
image-20220712202258418

如果要查看某一层的信息,你需要切换当前的栈,一般来说,程序停止时,最顶层的栈就是当前栈,如果你要查看栈下面层的详细信息,首先要做的就是切换当前。

  • frame/f n
代码语言:javascript
复制
frame n
f n

n是一个从0开始的整数,是栈中的层编号,比如:frame 0,表示栈顶,frame 1,表示栈的第二层。

image-20220712203351347
image-20220712203351347
  • up
代码语言:javascript
复制
up n

表示向栈的上面移动n层,不指定n,则为向上移动一层。

  • down
代码语言:javascript
复制
down n

表示向栈的下面移动n层,不指定n,则为向下移动一层。


如若不想打印对应栈层的信息,可以使用如下三个命令。

代码语言:javascript
复制
   select-frame n #对应于 frame 命令
   up-silently n #对应于 up 命令
   down-silently n #对应于 down 命令

  • frame/f

frame/f查看当前栈层信息。 会打印出:

  • 栈的层编号
  • 当前的函数名
  • 函数参数值
  • 函数所在文件及行号
  • 函数执行到的语句
  • info frame/f

可以查看到更详细的当前栈层的信息,只不过,大多数都是运行时的内存地址。比如:函数地址,被调用函数的地址,目前的函数是由什么样的程序语言写的,函数的参数地址及值,局部变量的地址等。如下图所示。

image-20220712205959026
image-20220712205959026
  • info args

打印出当前函数的参数名及其值。

  • info locals

打印出当前函数中所有局部变量及其值。

image-20220712210329495
image-20220712210329495
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-07-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Coredump 调试
    • Coredump是什么?
      • 前期设置
        • 什么情况下会导致程序异常退出?
          • 如何调试
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档