我正在编写一个程序,它有两个for循环,在第一个for循环期间(只打印1-5,在中间休眠1秒),SIGINT和SIGQUIT将被阻塞,而在第二个for循环中,只有SIGINT被阻塞。我成功地阻止了第一个for循环的正确信号,然后在第二个for循环上,我试图从阻塞SIGQUIT中删除SIGQUIT,但这两个信号似乎仍然被阻塞。
以下是我现在掌握的情况:
#include <unistd.h>
#include <stdio.h>
#include <wait.h>
#include <signal.h>
#include <string.h>
void hd1(int sig){
if(sig == SIGINT){
printf(" SIGINT Recieved\n");
}else if(sig == SIGQUIT){
printf(" SIGQUIT Recieved\n");
}
}
int main(){
sigset_t new_set;
sigset_t old_set;
//struct sigaction act;
//memset(&act, 0, sizeof(act));
//act.sa_handler = hd1;
//sigaction(SIGINT, &act, 0);
//sigaction(SIGQUIT, &act, 0);
sigemptyset(&new_set);
sigaddset(&new_set, SIGINT);
sigaddset(&new_set, SIGQUIT);
sigprocmask(SIG_BLOCK, &new_set, &old_set);
for(int i = 1; i <= 5; i++){
printf("%d\n", i);
sleep(1);
}
sigdelset(&new_set, SIGQUIT);
for(int i = 1; i <= 5; i++){
printf("%d\n", i);
sleep(1);
}
}我尝试过使用sigprocmask来解除阻塞,设置掩码来重置掩码,但是当我解除阻塞信号时,它会在循环结束后终止程序。
发布于 2017-11-01 16:46:04
只需第二次使用sigprocmask();。并使用SIG_SETMASK
SIG_SETMASK被阻塞的信号集设置为参数集。
sigdelset(&new_set, SIGQUIT);
sigprocmask(SIG_SETMASK, &new_set, NULL);https://stackoverflow.com/questions/47059627
复制相似问题