怎样使编写的程序可以被Ctrl + C结束??

发布于 2022-07-19 14:32:29 字数 105 浏览 20 评论 3

我发现我写的有些程序可以被Ctrl +C结束,有些不行,都不是守护进程。

是响应信号吗?

和多线程有没有关系

和内核版本有没有关系?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

清风不识月 2022-07-23 04:27:28

自己写一个信号处理函数,捕捉信号进行处理就可以了,但是对于fork()创建的多个进程连同原来的父进程,似乎对这个中断信号没有默认的处理,而单个进程在收到这个信号时就退出了,我也理解的不太透彻
比如:
#include <stdio.h>
int main(void)
{
while(1)
  {
   sleep(1);
    printf("sleeping.......n");
  }
}
这个进程启动后,接收到ctr+c就会退出
而对于
#include <unistd.h>
#include <stdio.h>
int main(void)
{
  if(fork()==0)
   {
    while(1)
    {
     printf("baby sleeping........n");
      sleep(1);
   }
   }else
   {
     printf("daddy sleeping.......n");
     sleep(1);
   }
  }
虽然能够收到中断信号,但是进程却不会退出,加上一个信号处理函数就可以了
#include <unistd.h>
#include <stdio.h>
#include <signal.h>
void sigint_handle(int sig)
{
  printf("signal received!n");
  exit(1);
}
int main(void)
{
struct  sigaction act;
  act.sa_handler = sigint_handle;
  sigemptyset(&act.sa_mask);
  act.sa_flags = 0;
  //sigaction(SIGINT,&act,NULL);
  if(fork()== 0)
  {
    while(1)
    {
      printf("child.......n");
      sigaction(SIGINT,&act,NULL);
      sleep(1);
    }
   }else
{
     while(1)
     {
         printf("father...........n");
        sigaction(SIGINT, &act,NULL);
         sleep(1);
      }
   }
}

樱花细雨 2022-07-22 12:39:30

只要SIGINT 不控制不让程序强制中断就可以!

作妖 2022-07-21 20:44:20

默认 SIGINT 的行为就是结束进程。如果不对 SIGINT 作出响应的程序都是被结束的。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文