原文连接:https://blog.csdn.net/jctian000/article/details/79695006函数
当咱们配置好自动生成core文件的环境后,若不想写致使崩溃的程序验证,那要怎么快速产生core呢?
先看下产生core文件的条件:
当程序接收到如下UNIX信号会产生core文件:.net
在系统默认动做列,“终止w/core”表示在进程当前工做目录的core文件中复制了该进程的存储图像(该文件名为core,由此能够看出这种功能好久以前就是UNIX功能的一部分)。大多数UNIX调试程序都使用core文件以检查进程在终止时的状态。
core文件的产生不是POSIX.1所属部分,而是不少UNIX版本的实现特征。UNIX第6版没有检查条件(a)和(b),而且其源代码中包含以下说明:“若是你正在找寻保护信号,那么当设置-用户-ID命令执行时,将可能产生大量的这种信号”。4.3 + BSD产生名为core.prog的文件,其中prog是被执行的程序名的前1 6个字符。它对core文件给予了某种标识,因此是一种改进特征。
表中“硬件故障”对应于实现定义的硬件故障。这些名字中有不少取自UNIX早先在DP-11上的实现。请查看你所使用的系统的手册,以确切地肯定这些信号对应于哪些错误类型。
下面比较详细地说明这些信号。
• SIGABRT 调用abort函数时产生此信号。进程异常终止。
• SIGBUS 指示一个实现定义的硬件故障。
• SIGEMT 指示一个实现定义的硬件故障。
EMT这一名字来自PDP-11的emulator trap 指令。
• SIGFPE 此信号表示一个算术运算异常,例如除以0,浮点溢出等。
• SIGILL 此信号指示进程已执行一条非法硬件指令。
4.3BSD由abort函数产生此信号。SIGABRT如今被用于此。
• SIGIOT 这指示一个实现定义的硬件故障。
IOT这个名字来自于PDP-11对于输入/输出TRAP(input/output TRAP)指令的缩写。系统V的早期版本,由abort函数产生此信号。SIGABRT如今被用于此。
• SIGQUIT 当用户在终端上按退出键(通常采用Ctrl-\)时,产生此信号,并送至前台进
程组中的全部进程。此信号不只终止前台进程组(如SIGINT所作的那样),同时产生一个core文件。
• SIGSEGV 指示进程进行了一次无效的存储访问。
名字SEGV表示“段违例(segmentation violation)”。
• SIGSYS 指示一个无效的系统调用。因为某种未知缘由,进程执行了一条系统调用指令,
但其指示系统调用类型的参数倒是无效的。
• SIGTRAP 指示一个实现定义的硬件故障。
此信号名来自于PDP-11的TRAP指令。
• SIGXCPU SVR4和4.3+BSD支持资源限制的概念。若是进程超过了其软C P U时间限制,则产生此信号。
• SIGXFSZ 若是进程超过了其软文件长度限制,则SVR4和4.3+BSD产生此信号。
每一种信号又对应一个编号,用kill -l命令能够查看具体的对应列表:
找到一种知足产生core文件条件的信号,用kill 命令对应用程序发送此信号便可:
如: kill -6 6864
kill -11 6864
————————————————
版权声明:本文为CSDN博主「你好xyz」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处连接及本声明。
原文连接:https://blog.csdn.net/jctian000/article/details/796950063d