Linux下信号与Core Dump(gdb调试)

本文介绍了Linux系统下的信号机制,包括信号的三种处理动作、如何查看系统信号及信号产生的四种方式。重点讨论了Core Dump的概念及其在调试中的应用,特别是利用gdb进行Post-mortem Debug。同时,通过代码示例展示了如何处理指针非法操作导致的信号异常,以及如何自定义发送信号给进程。
摘要由CSDN通过智能技术生成

信号:当一个进程产生异常、中断等时,操作系统则给进程发送一个信号,即向进程PCB中写入一个信息(此处即修改一个比特位(位图实现),表示进程是否收到该信号),当进程确认收到该信号则会在恰当的时间去执行其对应的相关处理动作。

三种处理动作:

1.忽略此信号;

2. 执行该信号的默认处理动作(一般都为终止此进程);
3. 提供一个用户自定义信号处理函数,内核处理时切换到用户态执行,即为信号的捕捉。

信号捕捉函数:

#include <signal.h>
typedef void (*sighandler_t)(int);  //函数指针,信号处理函数,参数为信号编号
sighandler_t signal(int signum,sighandler_t handler);    
参数:

signum:信号编号;

handler:自定义的信号处理函数指针

可用以下命令查看当前系统下的信号:

kill -l


其中1~31是常用信号,其中9号信号不可以被捕捉,34~64则成为实时信号。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值