4

所以我正在用 C 设计一个基本的 UNIX shell。

    signal(SIGCHLD, handler);
        pid = fork();
        switch (pid) {
        case -1: printf("Fork failed; cpid == -1\n");
        break;

        case 0: child_pid = getpid();
                argv[0] = prog;
        argv[1] =NULL;
        //exit(0);
        sid = setsid();
        execv(absPath,argv);        
        //printf("%d: this is the child, pid = %d\n", i, child_pid);
        //sleep(1);
        //exit(0);
        break;

        default: printf("This is the parent: waiting for %d to finish\n", pid);
        waitpid(pid, NULL, WNOHANG);
        printf("Ttttthat's all, folks\n");
        //break;
        }
        //execv(absPath,argv);
        //printf("CHILD PROCESS");
    }

}
void handler(int sig)
{
  pid_t pid;

  pid = wait(NULL);

  printf("Pid %d exit.\n", pid);
  exit(0);
}

但它仍然在同一个 shell 中执行分叉的进程,尽管在“默认”子句之后。

你能帮我让它作为后台进程运行吗?谢谢!

PS:这只是一个片段。

4

2 回答 2

2

评论一些明显的错误:

  • 在子进程中,您执行exit(0);因此立即退出子进程。删除此行。
  • 我认为为清楚起见,您应该execv()这样称呼execv(argv[0], argv);

Edit: Read the following to solve the problem with forking from a child process.

于 2012-04-25T08:38:13.860 回答
1

作为我的 Fat Controller 应用程序的一部分,我创建了一个库来守护进程。下载源代码并查看 daemonise.c - 它应该得到很好的评论,但如果您有任何其他问题,那么我很乐意提供帮助。

http://sourceforge.net/projects/fat-controller/files/

于 2012-04-25T08:24:27.160 回答