1.不可靠信号和可靠信号
建立在早期的信号处理机制上**(1~31)的信号是不可靠信号**
不支持排队、可能会丢失,如果同一个信号连续产生多次,进程可能只相应了一次
如果解除屏蔽,取决于可靠性!!!1
建立在新的信号处理机制上**(34~64)的信号是可靠信号**
支持排队、信号不会丢失
2. int pause(void)
功能:让调用者进入休眠状态,直到进程遇到信号才会唤醒
返回值:要么不返回在休眠,要么唤醒后返回-1
相当于没有时间限制的sleep
unsigned int sleep(unsigned int seconds);
功能:让调用者进入休眠指定的秒数,当遇到信号时会提前唤醒返回
返回值:剩余的休眠时间
c
1 #include <stdio.h>
2 #include<unistd.h>
3 #include<signal.h>
4 void sigint(int num)
5 {
6 printf("sigint%d\n",num);
7 }
8
9
10 void sigquit(int num)
11 {
12 printf("sigqiut:%d\n",num);
13 }
14
15 int main(int argc,const char* argv[])
16 {
17 printf("%d\n",getpid());
18
19 signal(SIGINT,sigint);
20 signal(SIGQUIT,sigquit);
21
22 sigset_t set ,oldset;
23 sigemptyset(&set);
24
25 sigaddset(&set,SIGINT);
26 sigaddset(&set,SIGQUIT);
27 //sigaddset(&set,SIGKILL);
28
29 sigfillset(&set);
30
31 sigprocmask(SIG_SETMASK,&set,&oldset);
32 sleep(5);//解除屏蔽5s内不会处理信号,因为不排队,不可靠性导致
33 //0-31都都不可靠的信号不会排队
34 //33-64是可靠的信号,会进行排队
35 sigprocmask(SIG_SETMASK,&oldset,NULL);
36 for(;;);
37
38
39 return 0;
屏蔽了cv,输入无效,已经被屏蔽了,sleep 5秒后开开始接受信号,
5秒之前发的信号,都无效,因为1-31信号是不排队的,不可靠
如果是34-64信号,输入都会排队,等sleep 5秒后,开始接受信号,
5秒前发的信息都会执行,可靠的