2、信号操作

2、信号操作
有时候我们希望进程正确的执行,而不想进程受到信号的影响,比如我们希望上面那个
程序在1 秒钟之后不结束.这个时候我们就要进行信号的操作了.信号操作最常用的方法是信
号屏蔽.信号屏蔽要用到下面的几个函数.
#include <signal.h>
25
int sigemptyset(sigset_t *set);
int sigfillset(sigset_t *set);
int sigaddset(sigset_t *set,int signo);
int sigdelset(sigset_t *set,int signo);
int sigismember(sigset_t *set,int signo);
int sigprocmask(int how,const sigset_t *set,sigset_t *oset);
sigemptyset 函数初始化信号集合set,将set 设置为空.sigfillset 也初始化信号集合,只
是将信号集合设置为所有信号的集合.sigaddset 将信号signo 加入到信号集合之中,sigd
elset 将信号从信号集合中删除.sigismember 查询信号是否在信号集合之中.
sigprocmask 是最为关键的一个函数.在使用之前要先设置好信号集合set.这个函数的作
用是将指定的信号集合set 加入到进程的信号阻塞集合之中去,如果提供了oset 那么当前
的进程信号阻塞集合将会保存在oset 里面.参数how 决定函数的操作方式.
SIG_BLOCK:增加一个信号集合到当前进程的阻塞集合之中.
SIG_UNBLOCK:从当前的阻塞集合之中删除一个信号集合.
SIG_SETMASK:将当前的信号集合设置为信号阻塞集合.
以一个实例来解释使用这几个函数.
#include <signal.h>
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
int main(int argc,char **argv)
{
double y;
sigset_t intmask;
int i,repeat_factor;
if(argc!=2)
{
fprintf(stderr,"Usage:%s repeat_factor\n\a",argv[0]);
exit(1);
}
if((repeat_factor=atoi(argv[1]))<1)repeat_factor=10;
sigemptyset(&intmask); /* 将信号集合设置为空 */
sigaddset(&intmask,SIGINT); /* 加入中断 Ctrl+C 信号*/
while(1)
{
/*阻塞信号,我们不希望保存原来的集合所以参数为NULL*/
sigprocmask(SIG_BLOCK,&intmask,NULL);
fprintf(stderr,"SIGINT signal blocked\n");
for(i=0;i<repeat_factor;i++)y=sin((double)i);
fprintf(stderr,"Blocked calculation is finished\n");
/* 取消阻塞 */
sigprocmask(SIG_UNBLOCK,&intmask,NULL);
fprintf(stderr,"SIGINT signal unblocked\n");
for(i=0;i<repeat_factor;i++)y=sin((double)i);
26
fprintf(stderr,"Unblocked calculation is finished\n");
}
exit(0);
}
程序在运行的时候我们要使用Ctrl+C 来结束.如果我们在第一计算的时候发出SIGINT
信号,由于信号已经屏蔽了,所以程序没有反映.只有到信号被取消阻塞的时候程序才会结束.
注意我们只要发出一次SIGINT 信号就可以了,因为信号屏蔽只是将信号加入到信号阻塞集
合之中,并没有丢弃这个信号.一旦信号屏蔽取消了,这个信号就会发生作用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值