linux core dump文件生成和调试

1.core dump文件生成

新建工程coredumptest
(1)CMakeList.txt设置
在CMakeList.txt中增加用于调试的编译选项
详细的参数意义参考https://blog.csdn.net/rheostat/article/details/19811407

project(coredumptest)
cmake_minimum_required(VERSION 2.8)
add_compile_options(-std=c++11 -pthread -g  -ggdb -O0 -Wall   -fstack-protector-all -march=native -fnon-call-exceptions)
aux_source_directory(. SRC_LIST)
add_executable(${PROJECT_NAME} ${SRC_LIST})

其中-g表示使用debug编译,
-ggdb:在可执行文件中包含可供GDB使用的调试信息
-O0 表示编译时不优化,关闭所有优化选项
-Wall 开启大部分警告提示
-fstack-protector-all 保护栈信息
使用 -march=native,GCC会自动检测你的CPU支持的指令集。
-fnon-call-exceptions 产生的代码可供陷阱指令(如非法浮点运算和非法内存寻址)抛出异常,需要相关平台的运行时支持,并不普遍有效
(2)测试用例

#include 
int main()
{
    char *ptr="linuxers.cn";
    *ptr=0;
}

运行时会报段错误.
(3)设置core文件大小

系统默认是不生成core文件的,只有手动输入ulimit -c xx命令才会产生core文件

ulimit -c 1024 设置core文件最大为1024k  
ulimit -c unlimited 不限制core文件大小

运行
./coredumptest
发现可执行程序文件夹下生成了core文件.
注意ulimit -c unlimited 只在当前路径下有效,换个路径输入ulimit -c发现为0

2使用gdb分析,查看堆栈情况

输入命令 gdb ./coredumptest core
输出如下,

Reading symbols from ./coredumptest...done.
[New LWP 28151]
Core was generated by `./coredumptest'.
Program terminated with signal SIGSEGV, Segmentation fault.
#0  0x00000000004007e0 in main ()
    at /home/rootroot/workspace/AProgramtest/coredumptest/main.cpp:6

at /home/rootroot/workspace/AProgramtest/coredumptest/main.cpp:6
表示main.cpp的第6行出现错误

3.永久生成coredump文件

多线程程序中的有些错误并不是每次都能够出现的,偶尔出现一次可是很难得的,此时就需要保存错误现场,便于慢慢分析.那么就需要出现coredump的时候就能够生成和保存core文件.
永久性的生成coredump文件,在/etc/bashrc或者~/.bashrc文件中加ulimit -c unlimited
重启电脑,输入ulimit -c 输出为unlimited

你可能感兴趣的:(学习linux)