linux信号与系统调用的关系.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  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文档。上传文档
查看更多
linux信号与系统调用的关系.doc

信号与系统调用的关系: 当一个进程正在执行一个系统调用时,如果向该进程发送一个信号,那么对于大多数 系统调用来说,这个信号在系统调用完成之前将不起作用,因为这些系统调用不能被信号 打断。但是有少数几个系统调用能被信号打断,例如: wait(),pause()以及对慢速设备 (终端、 打印机等)的 read()、 write()、 open()等。如果一个系统调用被打断,它就返回-1,并将 errno 设为 EINTR。可以用下列代码来处理这种情况: if (wirte(tfd,buf,SIZE)0) { if (errno==EINTR) { warn(“ Write interrupted.” ); … … } } 信号的复位: 在 Linux 中,当一个信号的信号处理函数执行时,如果进程又接收到了该信号,该信 号会自动被储存而不会中断信号处理函数的执行,直到信号处理函数执行完毕再重新调用 相应的处理函数。下面的程序演示了这一点: #include stdio.h #include signal.h int catch(int sig); //信号绑定函数,必须在main函数前声明。 int main(void) { printf(the program is starting.\n); signal(SIGINT, catch);//接受到SIGINT信号,执行绑定的catch函数 //signal(SIGINT, SIG_DFL);//SIG_DFL 恢复成系统的缺省动作 //signal(SIGINT, SIG_IGN);//告诉进程将 SIGINT 信号忽略,CTRL+C sleep(10); printf(the end.\n); return 0; } int catch(int sig) { printf(Interrupt called.\n); sleep(4); printf(“Interrupt Func end.\n”); } 执行它,结果如下: the program is starting. ctrl+c Interrupt called ctrl+c Interrupt Func end. Interrupt called Interrupt Func end. the end 只能保存一个CTRL+C。 如果在信号处理函数执行时进程收到了其它类型的信号,该函数的执行就会被中 断:the program is starting. ctrl+c Interrupt called ctrl+\ Quit called Quit ended. Interrupt Func end。 the ended. 在进程间发送信号: 个进程通过对 signal()的调用来处理其它进程发送来的信号。一个进程也可以向其它的进程发送信号。这一操作是由系统调用 kill()来完成的。 kill()在 linux 系统库 signal.h中的函数声明:int kill(pid_t pid, int sig); 参数 pid 指定了信号发送的对象进程:它可以是某个进程的进程标识符(pid),也可以是以下的值: 如果 pid 为零,则信号被发送到当前进程所在的进程组的所有进程; 如果 pid 为-1 ,则信号按进程标识符从高到低的顺序发送给全部的进程(这个过程受 到当前进程本身权限的限制); 如果 pid 小于-1,则信号被发送给标识符为 pid 绝对值的进程组里的所有进程。 需要说明的是,一个进程并不是向任何进程均能发送信号的,这里有一个限制,就是 普通用户的进程只能向具有与其相同的用户标识符的进程发送信号。也就是说,一个用户 的进程不能向另一个用户的进程发送信号。只有 root 用户的进程能够给任何线程发送信号。 参数 sig 指定发送的信号类型。它可以是任何有效的信号。 由于调用 kill()的进程需要直到信号发往的进程的标识符,所以这种信号的发送通常只 在关系密切的进程之间进行,比如父子进程之间。 下面是一个使用 kill()调用发送信号的例子。这个程序建立两个进程,并通过向对方发 送信号 SIGUSR1 来实现它们之间的同步。这两个进程都处于一个死循环中,在接收对方发 送的信号之前,都处于暂停等待中。这是通过系统调用 pause()来实现的,它能够使一个程 序暂停,直至一个信号到达,然后进程输出信息,并用 kill 发送一个信号给对方。当用户 按了中断键,这两个进程都将终止。 #include signal.h int ntimes=0; main() { int pid,ppid; int p_action(), c_action(); /* 设定父进程的 SIGUSR1 */ signal(SIGU

文档评论(0)

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

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

1亿VIP精品文档

相关文档