您的位置:首页 > 运维架构 > Linux

linux下用core和gdb查询出现"段错误"的地方

2015-10-23 16:49 741 查看
有些时候,在执行一段C代码的时候,由于对一个非法内存进行了操作,在程序运行的过程中出现了"段错误"。遇到这种问题是非常无语的,只是提示了"段错误",其他什么都没有。如果我们一味地去看代码查找问题,那太疼苦了,因为我们都相信自己写的代码没问题。下面介绍一种方法,可以有效定位出现"段错误"的地方。

当我们的程序崩溃时,内核有可能把该程序当前内存映射到core文件里,方便程序员找到程序出现问题的地方。

1.什么是core dump?
core的意思是内存,dump的意思是扔出来,堆出来。

2.为什么没有core文件生成呢?
有时候程序down了,但是core文件却没有生成。core文件生成与否,跟你当前系统的环境设置有关系,可以用下面的语句设置一下,便可生成core文件了。
$ ulimit  -c  unlimited
core 文件生成的位置一般与运行程序的路径相同,在ubuntu下文件名一般 为core。

3.什么是core文件?
当一个程序奔溃时,在进程当前工作目录的core文件中复制了该进程的存储图像。core文件仅仅是一个内存映像(同时加上调试信息),主要是用来调试的。

4.下面我们来看看,怎样利用core文件来定位程序出现"段错误"的地方。
#include <stdio.h>

char * str = "test";

void core_test()

{

    str[1] = 'T';

}

int main()

{

    core_test();

    return 0;

}

程序运行结果:



从上面我们可以看出,第一次运行程序出现"段错误"并没有出现core文件,一般linux操作系统默认core文件的大小都是0,需要手动设置一下。

5.调试core文件
core文件是个二进制文件,需要用相应的工具来分析程序崩溃时的内存映像。
linux下可以用gdb来调试core文件 。



从上面,我们可以清楚地看到我们的程序是在那个地方出现了错误。有了这种方法,我们就可以不再那么惧怕"段错误"了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  c++ linux 日志