为什么不在fork()之后执行子代码?它永远不会成为孩子的代码部分。

时间:2014-01-21 01:10:20

标签: c linux fork pid

这是我的代码。我基本上想要创建一个子进程,它将通过execvp()执行一些命令。然而,程序永远不会到达那里,因为它永远不会打印“Got to child”。我不明白为什么。有人可以解释错误是什么吗?因为我认为我正在遵循t的程序。

    pid_t pid;
    pid = fork();

    if (pid < 0) { //if fork() returns less than 1 it failed
        fprintf(stderr, "fork failed");
        return 1;
    }
    else if (pid == 0) {  //for() returns 0 then this is the child process
        printf("Got to child");
        int exec;
        exec = execvp(args[0], args); /* (2) invoke execvp() */
        if (exec < 0) {
            printf("Error: executing command failed.\n");
            exit(1);
        }
    }
    else { //pid>0 therefore this is the parent process
        if (background == 0){
        wait(&status);
        printf("Got to parent");
        }
    }

2 个答案:

答案 0 :(得分:6)

这看起来像典型的模式,但我想知道是否

printf("Got to child");

没有\ n会导致未写入的缓冲区在执行exec时被抛弃,因此没有输出。

答案 1 :(得分:3)

您没有看到Got to child,因为您没有在邮件末尾添加换行符。如果添加换行符,您可能会突然看到该消息。如果您想要合理地确定看到输出,请在消息的末尾使用换行符。如果您想更加确定这样做,请添加fflush(stdout);fflush(0);

您无需测试execvp()的返回值。它只有在不成功时才会返回。您应该将错误消息报告给标准错误,而不是标准输出。