书中程序清单:10-15.c
#include "apue.h"
static void sig_int(int signo);
int main(void)
{
sigset_t newmask, oldmask, waitmask;
pr_mask("program start:");
if(signal(SIGINT, sig_int) < 0)
{
fprintf(stderr, "signal(SIGINT) error");
exit(1);
}
sigemptyset(&newmask);
sigaddset(&newmask, SIGINT);
if(sigprocmask(SIG_BLOCK, &newmask, &oldmask) < 0)
{
fprintf(stderr, "SIG_BLOCK error");
exit(1);
}
pr_mask("critical region: ");
sigemptyset(&waitmask);
sigaddset(&waitmask, SIGUSR1);
if(sigsuspend(&waitmask) != -1)
{
fprintf(stderr, "sigsuspend error");
exit(3);
}
pr_mask("after sigsuspend: ");
if(sigprocmask(SIG_SETMASK, &oldmask, NULL) < 0)
{
fprintf(stderr, "sigprocmask SIG_SETMASK error");
exit(4);
}
pr_mask("program exit: ");
exit(0);
}
static void sig_int(int signo)
{
pr_mask("in sig_int: ");
}
输出如下:
$./a.out
program start:
critical region: SIGINIT
^Cin sig_int: SIGINIT SIGUSR1
after sigsuspend: SIGINIT
program exit:
$
刚开始时,我很不理解为甚么在sig_int中,会输出SIGINT,以为SIGINT已经被屏蔽(sigsuspend替换了屏蔽字,而该屏蔽字中,并没有SIGINT),后来仔细看了书,原来是,在信号处理程序中,会自动把该信号加入当前进程的屏蔽字中。对于屏蔽信号,树种说的很清楚,是阻塞该信号,暂时不传送给进程。解除阻塞后,立即传送给进程。我做了实验,的确是这样。对于sigsuspend,书中说的很清楚,是<strong>替换</strong>当前屏蔽字,我也做了实验,的确是这样。