GDB调试Core文件
core dump文件
core dump又叫核心转储, 当程序运行过程中发生异常, 程序异常退出时, 由操作系统把程序当前的内存状况存储在一个core文件中, 叫core dump. (Linux中如果内存越界会收到SIGSEGV信号,然后就会core dump)
如果在程序core后却没有core dump文件生成,则可以通过命令ulimit -c或者ulimit -a查看core file大小的配置情况,如果为0,则表示系统关闭了dump core,可以通过ulimit -c unlimited打开。
下面通过一个例子来说明如何使用GDB调试core dump文件查找出导致程序core的原因,程序如下:
#include<iostream>
#include<vector>
#include<map>
using namespace std;
int fun()
{
int i=0;
return i;
}
int main()
{
fun();
vector<int> vec_int;
vec_int.push_back(1);
vec_int.push_back(2);
map<int, int> mapping;
mapping.insert(pair<int, int>(0, 1));
int *p;
*p = 1;
return 0;
}
编译该程序时使用命令g++ -g main.cpp -o main.o生成main.o的可执行文件。当运行该可执行文件后即会产生core文件。
使用gdb调试core文件的命令格式为:gdb [exec file] [core file],此处为gdb main.o core_main,然后使用bt或者where命令即可发现导致程序core的原因是*p=1。
如果生成的可执行文件需要有参数可以运行,则调试的命令为gdb [exec_file 参数1 参数2] -c [core file]