关闭

关于信号sigprocmask

311人阅读 评论(0) 收藏 举报
  sigemptyset(&new_mask);
  sigaddset(&new_mask,SIGQUIT); //将信号SIGQUIT,添加到空信号集new_mask中
  if(sigprocmask(SIG_BLOCK, &new_mask,&old_mask)) //把信号SIGQUIT给阻塞
  {
  printf("block signal SIGQUIT error\n");
  }

  sigemptyset(&zero_mask); //清空信号集zero_mask

  while(quitflag == 0)
  {
  sigsuspend(&zero_mask); //将当前的信号掩码替换成空信号掩码zero_mask,等待SIGQUIT消息处理函数将quitflag置为1  
  }

  if(sigprocmask(SIG_SETMASK,&old_mask,NULL)<0) //程序继续运行后恢复进程原来的信号掩码
  {
  printf("unblock signal error\n");
  }
是为了原子操作
如果之前没有调用sigprocmask()屏蔽SIGQUIT信号,那么SIGQUIT信号随时都能发生
假定恰恰在判断quitflag == 0之后,信号发生,调用信号处理程序,quitflag = 1
从信号处理程序返回后,开始调用sigsuspend()..
如果此后没有第二个SIGQUIT信号,那么程序将一直阻塞在sigsuspend(),虽然此时quitflag = 1

调用sigprocmask()屏蔽SIGQUIT信号之后,即使信号发生,也将延迟递交,直到sigsuspend()解除信号屏蔽。

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:112278次
    • 积分:1657
    • 等级:
    • 排名:千里之外
    • 原创:33篇
    • 转载:95篇
    • 译文:0篇
    • 评论:9条
    最新评论