Linux下程序运行路径下产生core文件

参考博文:linux(ubuntu)下设置在当前目录产生core文件_春风化雨&的博客-CSDN博客

2.设置core文件的格式
echo “1” > /proc/sys/kernel/core_uses_pid
echo “core.%e.%p” > /proc/sys/kernel/core_pattern

权限不够可以切换到root,%e表示相关的命令名,%p表示进程pid,还有其他的一些参数可选:
%p - insert pid into filename 添加pid
%u - insert current uid into filename 添加当前uid
%g - insert current gid into filename 添加当前gid
%s - insert signal that caused the coredump into the filename 添加导致产生core的信号
%t - insert UNIX time that the coredump occurred into filename 添加core文件生成时的unix时间
%h - insert hostname where the coredump happened into filename 添加主机名
%e - insert coredumping executable name into filename 添加命令名

产生的core文件默认在当前目录,也可指定到core文件到某个目录(需事先创建好):
echo “/tmp/core/core.%e.%p” > /proc/sys/kernel/core_pattern
 

如果想在程序运行的当前目录下产生core文件,一定要注意下面这条命令:

echo “core.%e.%p” > /proc/sys/kernel/core_pattern

即产生的文件名如:core.test.9933

但是,每次开机重启后,又失效了怎么办?

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Linux下,当一个Qt程序打包后,在运行时出现"Segmentation fault (core dumped)"的错误,通常是由于程序访问了不被允许的内存地址或发生了内存溢出等问题导致的。 首先,我们可以尝试查看生成的CoreDump文件,以便获取更多关于错误的详细信息。在终端中执行以下命令: ```shell $ gdb <path_to_your_program> core ``` 其中,`<path_to_your_program>`是你的程序路径,`core`是生成的CoreDump文件名。进入gdb调试界面后,可以使用`bt`命令查看调用栈信息,以确定错误发生的位置。 如果你的程序依赖于一些第三方库,那么这个问题可能与库版本不匹配有关。你可以尝试重新编译这些库或者更新到更新的版本。 另外,一些常见的导致该错误的问题包括: 1. 空指针引用:程序中使用了一个空指针,例如没有对指针进行初始化或没有正确判断指针是否为NULL。 2. 数组溢出:程序中访问了超出数组边界的元素,导致越界访问了不被允许的内存地址。 3. 内存泄漏:程序动态申请的内存没有被正确释放,导致内存溢出。 4. 未初始化的变量:使用了一个未初始化的变量,其值是不确定的,可能导致错误的操作。 为了解决这些问题,你可以使用一些工具来帮助调试,例如`valgrind`(检测内存泄漏和越界访问)或者`gdb`(动态调试器)等。这些工具会提供更详细的错误信息,帮助你定位和解决问题。 总之,"Segmentation fault (core dumped)"错误的出现通常是由于程序访问了不被允许的内存地址或发生了内存溢出等问题导致的。使用调试工具定位错误,修改代码以避免这些问题的出现是解决该错误的关键步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

唐•苏凯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值