setjmp,longjmp,isgsetjmp,siglongjump

本文探讨了Linux中使用setjmp和longjmp处理信号的问题,并对比了sigsetjmp和siglongjmp的使用方式,解决了信号重复捕获的技术难题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在学习Linux的编程,在学习到进程间通信时,学习的是基本的信号通信。学习完成之后,想写个简单的例子来复习下,没想到引起了一个问题,代码如下:

#include <stdio.h>
#include <unistd.h>
#include <signal.h>
#include <setjmp.h>

jmp_buf position1;
int catch(int sig)
{
longjmp(position1,1);
}


int main()
{
int i=0;
printf("good morming\n");
sigset(SIGALRM,(__sighandler_t)catch);
setjmp(position1,1);
alarm(2);
printf("enter %d\n",i++);
while(1);
return 0;
}

在到时的中断一次跳转之后,不再中断跳转。原来使用setjmp(),longjmp()函数时,但信号中断之后,自动的将该信号加入到屏蔽信号集中,因此再次到时时,不再能捕捉到信号。而使用sigsetjmp()和siglongjmp(),如果sigsetjmp的第二个参数值不为0,则不将该信号添加至屏蔽集。问题就可以解决;

#include <stdio.h>
#include <unistd.h>
#include <signal.h>
#include <setjmp.h>


jmp_buf position1;
int catch(int sig)
{
siglongjmp(position1,1);
}


int main()
{
int i=0;
printf("good morming\n");
sigset(SIGALRM,(__sighandler_t)catch);
sigsetjmp(position1,1);
alarm(2);
printf("enter %d\n",i++);
while(1);
return 0;
}

则可以一直捕获信号。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值