分析linux应用发生Segmentation fault段错误时(core dump)文件定位错误

问题描述:

linux应用在跑的时候,突然蹦掉,具体Log如下:

直接上报Segmentation fault出来,

下面部分转载自这位大佬:

https://zhuanlan.zhihu.com/p/641038731

先说说:什么是SIGSEGV, SIG是信号的通用前缀,SEGV是 Segmentation violation,也就是存储区段错误,SIGSEGV原因一般都是无效的内存引用,导致进程的异常终止。在Linux系统中,通常把“主内存”称为核心(core),而核心映像(core image)就是进程process执行当时的内存内容,当进程收到一个信号“single”而终止时,系统会将这个核心映像写入一个文件作为调试使用,这就是所谓的核心转储“core dump”,当一个程序蹦掉是就会生成一个core文件,可以将此文件生成在指定的路径。

Step1: 开启core dump文件存储, ulimit -c unlimited  //不限制产生的core的大小

Step2:查看core dump文件的生成路径: cat  /proc/sys/kernel/core_pattern

Step3: 修改core dump文件的生成路径: echo core /proc/sys/kernel/core_pattern

下面这位大佬解说来GDB的详细教程,详细查阅学习:

Linux | 调试器GDB的详细教程【纯命令行调试】_linux gdb 调试教程-CSDN博客

说了那么多,回到刚刚我们的应用为何crash, 依葫芦画瓢找到根源:

 可得知是卡壳在UpdataImageData()函数中。

  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值