Linux 应用 Segmentation fault 分析手段

本文详细介绍了在Linux系统中遇到Segmentation fault时,如何生成和分析core dump文件。通过设置`ulimit -c unlimited`开启core dump生成,并调整`/proc/sys/kernel/core_pattern`设置文件名。利用gdb进行分析,包括在板子端和PC端的步骤,以及设置动态库路径和查看堆栈信息,帮助定位并解决问题。
摘要由CSDN通过智能技术生成

前言

本文主要介绍,在Linux 下应用程序发生Segmentation fault 错误时,如何使用gdb 通过core dump文件查找错误具体发生的地方。


一、生成core dump文件

在板子上执行ulimit -c 或者 ulimit -a 命令查看core 文件大小的配置情况,如下图所示

在这里插入图片描述
此时 “ core file size ”大小为0,说明系统没有打开core dump,解决方法:
执行ulimit -c unlimited 命令,让系统可以产生core dump文件
在这里插入图片描述

二、Core dump 文件名设置(可选)

core dump 文件默认会生成在当前文件夹(用户执行可执行文件的路径),名字就叫做core,core dump 文件的命名规则定义在/proc/sys/kernel/core_pattern文件中,如下图所示
在这里插入图片描述
可以通过修改/proc/sys/kernel/core_pattern的值来修改生

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值