1.什么是core文件

在unix或者类unix系统中,应用程序在运行过程中异常退出或者终止,在一定的情况下会产生一个叫做core的文件(默认可执行程序所处目录),core是一个进程的内存映像(包含了程序运行时的内存,寄存器状态,堆栈指针,内存管理信息还有各种函数调用堆栈信息等),通过分析这个文件,我们可以检查进程终止时的状态,定位程序异常退出的时候堆栈的调用等信息,找出问题所在。

2.core文件的位置

在进程当前工作目录(默认就是可执行程序所处目录),也可以通过类似chdir函数修改。

3.如何产生core文件(产生core文件的条件)

  • 首先需要确认当前会话的ulimit –c,若为0,则不会产生对应的coredump,需要进行修改和设置。运行ulimit  -c unlimited  (可以产生coredump且不受大小限制,大小也可限制,执行查看ulimit的使用),当然,这种设置只对当前回话有效。
  • 通过修改配置文件来调整core选项。vim  ~/.bashrc 在其中加入上述命令行(ulimit -c unlimited)即可,对当前登录用户一直有效。
  • 常见coredump原因:
  • 内存操作越界(以下列举一些实际中经常碰到的)
  • 数组操作越界
  • 字符串没有正常结束符(\0),比如动态分配内存,赋值字符串时结尾没有\0
  • 字符串操作函数strcpy, strcat, sprintf, strcmp操作不当
  • 使用了线程不安全的函数
  • 多线程读写的数据未加锁保护。
  • 违法指针(例如对空指针的不当操作,或者错误的强制指针转换)
  • 堆栈错误(超出了堆栈所分配的大小)

实例演示产生core文件

网上找了一段新手求助的代码(额,自己懒得写了)

 vim CreateCore.c

#include<stdio.h>
int main()
{
  void copy(char fr[],char to[]);
  char *a="I am a teacher.";
  char *b="you are a student.";
  printf("\nstring a=%s \nstring b=%s \n",a,b);
  printf("copy string a to string b: \n");
  copy(a,b);
  printf("\n string a=%s\n string b=%s\n",a,b);
}

void copy(char fr[],char to[])
{
  for(;(*to++=*fr++)!=0;);
}



sunxiaowu@sunxiaowu:~/Documents/sunCode$ gcc CreateCore.c  -g -o CreateCore
sunxiaowu@sunxiaowu:~/Documents/sunCode$ dir
byteOrder  byteOrder.c  CreateCore  CreateCore.c
sunxiaowu@sunxiaowu:~/Documents/sunCode$ ./CreateCore 

string a=I am a teacher. 
string b=you are a student. 
copy string a to string b: 
Segmentation fault (core dumped)
sunxiaowu@sunxiaowu:~/Documents/sunCode$ dir
byteOrder  byteOrder.c  core  CreateCore  CreateCore.c
sunxiaowu@sunxiaowu:~/Documents/sunCode$

果然产生了core

4.如何调试core文件

gdb -c 内核文件

Core was generated by `./CreateC'.
Program terminated with signal SIGSEGV, Segmentation fault.



通过上述信息可以查看是什么终止了进程的运行。然后bt,查看调用堆栈,定位出错的具体位置(gdb调试程序那一套,此处不复述)