进程间通信管道与信号-课件.pptVIP

  • 3
  • 0
  • 约2.25万字
  • 约 74页
  • 2018-11-24 发布于广东
  • 举报
例:signal的应用 #include stdio.h #include signal.h #include unistd.h #include stdlib.h void fun_ctrl_c(); int main(){ (void)signal(SIGINT,fun_ctrl_c); printf(Now Im starting\n); while(1) { printf(this is an endless loop unless Ctrl+c are pressd!\n); sleep(2); } exit(0);} * * 例:signal的应用 void fun_ctrl_c(){ printf(\tCtrl+c were pressed!\n); printf(\t This is just an example for signal function!\n); printf(\treset signal SIGINT\n); (void)signal(SIGINT,SIG_DFL);} * * sigaction安装信号 extern int sigaction(int __sig, struct sigaction *__act, struct sigaction *__oact) 此函数的第一个参数为接收到的信号,第二、三个参数均为信号结构sigaction(用于描述要采取的操作及相关信息,见后续说明)变量。第二个参数用来指定欲设置的信号处理信息,第三个参数将返回执行此程序前信号处理信息。 如果第二个参数act不为空指针,则指定信号关联的操作为此参数指向的结构。如果参数oact不为空指针,则用来存储以前设置的与此信号关联的操作。 如果参数act为空指针,则信号处理保持不变;因此,该调用可用于询问对指定信号的当前处理。 * * struct sigaction Struct sigaction{ union{ __sighandler_t _sa_handler; void(*_sa_sigaction)(int , struct siginfo *, void *); } __u; sigset_t sa_mask; unsigned long sa_flags; void(*sa_restorer)(void); }; #define sa_handler _u.sa_handler #define sa_sigaction _u._sa_sigaction * * 例:sigaction的应用 #include stdio.h #include stdlib.h #include signal.h void myhandler(int sig); int main(){ struct sigaction act,oact; act.sa_handler=myhandler; sigemptyset(act.sa_mask); act.sa_flags=0; sigaction(SIGUSR1,act,oact); while(1) { printf(hello world!\n); pause(); }} * * void myhandler(int sig){ printf(the signal %d was caught.\n,sig);} 信号集与屏蔽信号 中断是可以被屏蔽(阻塞)的(部分硬件中断是必须立即处理的,例如复位中断),因此,Linux的信号是可以屏蔽,即阻塞信号。但这与前面提到的忽略是有区别的。 信号忽略:系统仍然传递该信号,只是相应进程对该信号不作任何处理而已。 信号阻塞:系统不传递该信号,显示该进程无法接收到该信号直到进程的信号集发生改变。 * * sigprocmask设置进程阻塞的信号集 extern int sigprocmask(int __how, __const sigset_t * __restrict__set, sigset_t * __restrict__oset) 此函数第一个参数为更改该集合的方式,如下所示: //come from /usr/include/asm/signal.h #define SIG_BLOCK 0 /*for blocking signals */ #define SIG_UNBLOCK 1 /*for unblocking signals */ #define SIG_SETMASK 2 /*for setting the signal mask */ SIG_BLOC

文档评论(0)

1亿VIP精品文档

相关文档