【Z】段错误Segment Fault定位,即core dump文件与gdb定位
使用C++开发系统有时会出现段错误,即Segment Fault。此类错误程序直接崩溃,通常没有任何有用信息输出,很难定位bug,因而无从解决问题。今天我们介绍core dump文件,并使用gdb进行调试,以此来定位段错误问题。此文同时用以备忘。
一、core dump
Core dump也称核心转储, 当程序运行过程中异常退出时, 由操作系统把程序当前的内存状况存储在一个core文件中, 称之为core dump文件。
系统默认不生成core dump文件,可以使用ulimit命令进行查看和设置。
查看。使用ulimit -c 或 ulimit -a命令查看core dump文件大小,如果core file size为0,则表示此时系统不会自动生成core dump文件,具体情况如图1所示。

图1
设置。我们可以通过ulimit-c unlimited命令,将core file size设置为不受限制unlimited,以此配置系统,使之可以自动生成coredump文件,具体操作如图2所示。

图2
二、段错误程序
我们编写一段简单的段错误程序,将之命名为core_test.cpp,代码如下。编译运行,系统自动产生了core文件,如图3所示。
#include<assert.h>
int main() {
assert(0);
return 0;
}

图3
三、core文件命名
在生产环境中,一台服务器上运行的程序较多,如果所有程序的core dump文件都自动命名为core,则可能造成一定的混乱。为此,我们可以通过设置,使得系统在为core dump文件命名时注明更多信息。
进程号。通过以下设置,可以使core dump文件名为core.pid形式。如图4所示,系统自动生成了core.3430文件。
echo "1" >/proc/sys/kernel/core_uses_pid

图4
更多信息。通过以下设置,可以使core dump文件名为core-exe-pid-time形式。如图4所示,系统自动生成了core-core_test-3465-1416037828文件。
echo “/coredir/core-%e-%p-%t” > /proc/sys/kernel/core_pattern/
图5
如果我们想进一步订制core文件的名称,可以根据表1的信息,进行设置。
表1
|
%% 单个%字符 %p 进程ID %u 进程实际用户ID %g 进程的实际组ID %s 导致本次core dump的信号 %t core dump的时间戳 (由1970年1月1日计起的秒数) %h 主机名 %e 程序文件名 |
四、使用gdb定位core dump错误
部分博友的博客中提到使用gdb –c core与where命令定位错误。或许是因为配置不同,我实际操作后发现如果使用gdb –c core,则获得的定位信息不具有可读性,具体如图6所示。

图6
最终,我使用gdb core_test core命令(其中core_test是发生dump的可执行程序,core是core file),进入gdb后,再使用where命令,可以定位到发生dump的代码位置,并且具有良好的可读性,具体如图7所示。

图7
参考
http://blog.csdn.net/ithomer/article/details/5945152
【Z】段错误Segment Fault定位,即core dump文件与gdb定位的更多相关文章
- Segment fault及LINUX core dump详解 (zz)
C 程序在进行中发生segment fault(core dump)错误,通常与内存操作不当有关,主要有以下几种情况: (1)数组越界. (2)修改了只读内存. (3)scanf("%d&q ...
- Segment fault及LINUX core dump详解
源自:http://andyniu.iteye.com/blog/1965571 core dump的概念: A core dump is the recorded state of the work ...
- 利用linux信号机制调试段错误(Segment fault)
在实际开发过程中,大家可能会遇到段错误的问题,虽然是个老问题,但是其带来的隐患是极大的,只要出现一次,程序立即崩溃中止.如果程序运行在PC中,segment fault的调试相对比较方便,因为可以通过 ...
- 利用linux信号机制调试段错误(Segment fault)【转】
转自:http://blog.csdn.net/ab198604/article/details/6164517 版权声明:本文为博主原创文章,未经博主允许不得转载. 在实际开发过程中,大家可能会遇到 ...
- 造成segment fault,产生core dump的可能原因
1.内存访问越界 a) 由于使用错误的下标,导致数组访问越界 b) 搜索字符串时,依靠字符串结束符来判断字符串是否结束,但是字符串没有正常的使用结束符 c) 使用strcpy, strcat, spr ...
- Linux下如何生成core dump 文件(解决segment fault段错误的问题)
Linux下的C程序常常会因为内存访问等原因造成segment fault(段错误),如果此时core dump 的功能是打开的,在运行我们的可执行程序时就会生成一个名为core的文件,然后我们就可以 ...
- linux core dump 文件 gdb分析
core dump又叫核心转储, 当程序运行过程中发生异常, 程序异常退出时, 由操作系统把程序当前的内存状况存储在一个core文件中, 叫core dump. (linux中如果内存越界会收到SIG ...
- 用gdb调试程序笔记: 以段错误(Segmental fault)为例
用gdb调试程序笔记: 以段错误(Segmental fault)为例[转] 1.背景介绍2.程序中常见的bug分类3.程序调试器(如gdb)有什么用4.段错误(Segmental fault)介绍5 ...
- linux C++ 莫名奇异的段错误(segmentation fault),无法调用其他函数
进来在linux下开发C++项目,遇到了非常奇怪的bug. 项目须要多线程实现,在写好代码后,每当执行到线程函数内部,当内部调用其他函数如printf.fopen等时就会提示段错误(segmentat ...
随机推荐
- 在C代码中将结构体变量作为参数传递效率忒低
在C语言编程中,我们几乎不可能看见有人将一个结构体变量作为参数进行传递,因为效率太低了.本文尝试从反汇编的角度给出其中的缘由. 对于C语言来说,所有的参数传递都是值传递.如果一个变量为指针,那么传递的 ...
- idea 下 启动maven项目,mybatis报错 Error parsing SQL Mapper Configuration. Cause: java.io.IOException。。。。。
我的具体报错日志是 Error parsing SQL Mapper Configuration. Cause: java.io.IOException Could not find resou ...
- mongodb配置文件与启动
数据库配置文件 mongo.cnf #日志文件位置 logpath=/data/db/journal/mongodb.log (这些都是可以自定义修改的) # 以追加方式写入日志 logappend= ...
- 将forme表单转换为Json对象
//将Form 表单转换为Json字符串 $.fn.serializeObject = function () { var o = {}; var a = this.serializeArray(); ...
- SQL 工具系列一
1.误删除数据恢复篇 ApexSQL Recover 可以恢复Delete Truncate drop,恢复 二进制大型对象 测试版本 每10行才会恢复 评估版本下载地址:只能用14天 所以基 ...
- 告别Flash——那些年我们追过的FusionCharts
随着FusionCharts最终放弃Flash这块蛋糕,不.或者已经不能叫做蛋糕了,现在Flash图表控件就只剩下AnyChart这一个独苗了,到底Flash还能走多远?这是Flash的末路吗? 众说 ...
- Kettle系列文章二(安装配置Kettle+SqlServer+简单的输入输出作业)
一.下载 Kettle下载地址:https://community.hitachivantara.com/docs/DOC-1009855 下拉到DownLoad,点击红框中的链接进行下载.. 二.解 ...
- ajax传json
需求 前台有许多字段需要用ajax传送给后台, 如果给直接将字段封装成JSON对象传给后台会很方便 解决 ajax 发送 var str = {"name":"xiaom ...
- Java基础(十一)集合框架
一.集合框架 1.集合框架定义 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常 ...
- 冒泡排序——Python实现
一.排序思想 排序思想参见:https://www.cnblogs.com/luomeng/p/10161794.html 二.python实现 def bubble_sort(nums): &quo ...