2

我的问题听起来与此相同,但事实并非如此:

在Linux中使用C在后台启动一个进程

我知道如何做 fork() 但不知道如何将进程发送到后台。我的程序应该像一个支持管道和后台进程的简单命令 unix shell 一样工作。我可以做管道和叉子,但我不知道如何使用程序&的最后一行将进程发送到后台:

~>./a.out uname
SunOS
^C
my:~>./a.out uname &

如何实现后台进程?

#include <sys/types.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>

#define TIMEOUT (20)

int main(int argc, char *argv[])
{
  pid_t pid;

  if(argc > 1 && strncmp(argv[1], "-help", strlen(argv[1])) == 0)
    {
      fprintf(stderr, "Usage: Prog [CommandLineArgs]\n\nRunSafe takes as arguments:\nthe program to be run (Prog) and its command line arguments (CommandLineArgs) (if any)\n\nRunSafe will execute Prog with its command line arguments and\nterminate it and any remaining childprocesses after %d seconds\n", TIMEOUT);
      exit(0);
    }

  if((pid = fork()) == 0)        /* Fork off child */
    {
      execvp(argv[1], argv+1);
      fprintf(stderr,"Failed to execute: %s\n",argv[1]);
      perror("Reason");
      kill(getppid(),SIGKILL);   /* kill waiting parent */
      exit(errno);               /* execvp failed, no child - exit immediately */
    }
  else if(pid != -1)
    {
      sleep(TIMEOUT);
      if(kill(0,0) == 0)         /* are there processes left? */
    {
      fprintf(stderr,"\Attempting to kill remaining (child) processes\n");
      kill(0, SIGKILL);      /* send SIGKILL to all child processes */
    }
    }
  else
    {
      fprintf(stderr,"Failed to fork off child process\n");
      perror("Reason");
    }
}

简单英语的解决方案似乎在这里: 我如何在 C 的后台执行()一个进程?

捕获 SIGCHLD 并在处理程序中调用 wait()。

我在正确的轨道上吗?

4

1 回答 1

5

问:如何将进程发送到后台?

答:一般来说,正是你已经在做的事情:fork()/exec()。

问:什么没有按您的预期工作?

我怀疑也许你也想要一个“nohup”(完全解除孩子与父母的联系)。

这样做的关键是在子进程中运行“setsid()”:

于 2012-06-11T18:33:04.117 回答