进程间通信管道和信号.pptVIP

  1. 1、本文档共74页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
进程间通信管道和信号

例: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)

shuwkb + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档