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调试程序那一套,此处不复述)