当前位置: 技术问答>linux和unix
sigprocmask函数对不再阻塞信号的返回问题
来源: 互联网 发布时间:2016-02-22
本文导语: 上说:如果在调用s i g p r o c m a s k后有任何未决的、不再阻塞的信号,则在s i g p r o c m a s k返回前,至少将其中之一递送给该进程。 小弟用下列程序对这句话进行测试:先屏蔽掉SIGUSR1和SIGUSR2信号,然后用...
上说:如果在调用s i g p r o c m a s k后有任何未决的、不再阻塞的信号,则在s i g p r o c m a s k返回前,至少将其中之一递送给该进程。
小弟用下列程序对这句话进行测试:先屏蔽掉SIGUSR1和SIGUSR2信号,然后用kill函数发送他们,再打开它们.
可运行结果却是:
SIGUSR is blocked
SIGUSR1 function
SIGUSR2 function
SIGUSR1 function
SIGUSR is unblocked
为什么会返回两次SIGUSR1函数呢?谢谢回答
程序如下:
#include
#include
static void sig_usr1(signo)
{
printf("SIGUSR1 functionn");
}
static void sig_usr2(signo)
{
printf("SIGUSR2 functionn");
}
main()
{
sigset_t newmask,oldmask;
if(signal(SIGUSR1,sig_usr1)
小弟用下列程序对这句话进行测试:先屏蔽掉SIGUSR1和SIGUSR2信号,然后用kill函数发送他们,再打开它们.
可运行结果却是:
SIGUSR is blocked
SIGUSR1 function
SIGUSR2 function
SIGUSR1 function
SIGUSR is unblocked
为什么会返回两次SIGUSR1函数呢?谢谢回答
程序如下:
#include
#include
static void sig_usr1(signo)
{
printf("SIGUSR1 functionn");
}
static void sig_usr2(signo)
{
printf("SIGUSR2 functionn");
}
main()
{
sigset_t newmask,oldmask;
if(signal(SIGUSR1,sig_usr1)