【原创】《Linux高级程序设计》杨宗德著 - 进程管理与程序开发 - 等待信号
进程可以因等待某些特定的信号而阻塞、pause()函数用来等待除当前进程屏蔽信号集外的任意信号。
而sigsuspend()函数用来等待指定信号(由其参数指定,不受当前进程信号屏蔽集合的影响)以外的任意信号。
当收到某个信号后,进程屏蔽的信号将自动恢复到原来屏蔽的信号集合。
应用示例:
//test for sigsuspend
#include<signal.h>
#include<stdlib.h>
#include<errno.h>
#include<stdio.h>
void pr_mask(char *str)
{
sigset_t sigset01;
int errno_save;
errno_save=errno;
if(sigprocmask(0,NULL,&sigset01)<0)
perror("sigprocmask erro!");
printf("%s\n",str);
if(sigismember(&sigset01,SIGINT))
printf("SIGINT\n");
if(sigismember(&sigset01,SIGQUIT))
printf("SIGQUIT\n");
if(sigismember(&sigset01,SIGUSR1))
printf("SIGUSR1\n");
if(sigismember(&sigset01,SIGALRM))
printf("SIGALRM\n");
errno=errno_save;
}
static void sig_int(int signo)
{
printf("signo=%d\n",signo);
pr_mask("\ntest :in sig_int\n");
}
int main(void)
{
sigset_t newmask,oldmask,waitmask;
pr_mask("program start:");
if(signal(SIGINT,sig_int)==SIG_ERR)
perror("signal(SIGINT) error!!\n");
if(signal(SIGUSR1,sig_int)==SIG_ERR)
perror("signal(SIGUSR1) error");
sigemptyset(&waitmask);
sigaddset(&waitmask,SIGUSR1);
sigemptyset(&newmask);
sigaddset(&newmask,SIGINT);
if(sigprocmask(SIG_BLOCK,&newmask,&oldmask)<0)
perror("SIG_BLOCK erro!!\n");
pr_mask("in critical region:");
if(sigsuspend(&waitmask)!=-1)
perror("sigsuspend erro!!\n");
pr_mask("after return from sigsuspend:");
if(sigprocmask(SIG_SETMASK,&oldmask,NULL)<0)
perror("SIG-SETMASK erro!!\n");
while(1);
pr_mask("\nprogram exit:\n");
exit(0);
}
运行结果:
终端1:
$ ./sigsuspend_test &
[3] 3349
program start:
in critical region:
SIGINT
终端2:
$ kill -SIGUSR1 3349
kill -SIGINT 3349
终端1:
signo=2
test :in sig_int
SIGINT
SIGUSR1
signo=10
test :in sig_int
SIGINT
SIGUSR1
after return from sigsuspend:
SIGINT
终端2:
$ kill -SIGUSR2 3349
终端1:
[3]+ 用户定义信号 2 ./sigsuspend_test