1.不可靠信号和可靠信号
 建立在早期的信号处理机制上**(1~31)的信号是不可靠信号**
 不支持排队、可能会丢失,如果同一个信号连续产生多次,进程可能只相应了一次
 如果解除屏蔽,取决于可靠性!!!1
 建立在新的信号处理机制上**(34~64)的信号是可靠信号**
 支持排队、信号不会丢失
2. int pause(void)
 功能:让调用者进入休眠状态,直到进程遇到信号才会唤醒
 返回值:要么不返回在休眠,要么唤醒后返回-1
 相当于没有时间限制的sleep
unsigned int sleep(unsigned int seconds);
 功能:让调用者进入休眠指定的秒数,当遇到信号时会提前唤醒返回
 返回值:剩余的休眠时间
  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秒前发的信息都会执行,可靠的