2

我有这个代码:

            close(pipefd[0]);

            fp = fopen(argv[1], "r");

            if(fp)
            {
                while((c = getc(fp)) != EOF)
                {
                    if((write(pipefd[1], c, 1)) < 1)
                    {
                        fprintf(stderr, "Write to pipe failed.\n");
                        exit(EXIT_FAILURE);
                    }
                }
            }

            fclose(fp);

            close(pipefd[1]);   
            waitpid(childPID, &status, 0);
            exit(EXIT_SUCCESS);

据我了解,它应该打开一个文件并将其内容写入管道。然后这成为另一个程序的标准输入。我的测试表明除了写入之外一切正常,但我不知道为什么它不工作。

我只是在做一些愚蠢的事情吗?

编辑:是的,我在做一些愚蠢的事情。

我认为问题出在我的写入(在我修复 c 需要是 &c 之后),但它实际上是在我的子进程中,我使用 dup2() 将管道的读取端链接到我的子进程的标准输入. 我的论点倒退了。这是从 fork() 开始的工作代码:

childPID = fork();
if (childPID == 0)
{
    //child code
    //printf("In the child process.\n");
    dup2(pipefd[0], STDIN_FILENO);
    close(pipefd[1]);

    execv(argv[2], paramList);
    printf("You shouldn't be seeing this.\n");
}
else
{
    //parent code
    //printf("In the parent process\n");
    close(pipefd[0]);

    fp = fopen(argv[1], "r");

    if(fp)
    {
        while((c = getc(fp)) != EOF)
        {
            if((write(pipefd[1], &c, 1)) < 1)
            {
                fprintf(stderr, "Write to pipe failed.\n");
                perror("write");
                exit(EXIT_FAILURE);
            }
        }
    }

    fclose(fp);

    close(pipefd[1]);   
    waitpid(childPID, &status, 0);
    exit(EXIT_SUCCESS);
}

希望这可以帮助其他人不必在桌子上撞头四天!并感谢所有抽空回答的人。

4

1 回答 1

2

write()需要一个指向要写入的数据缓冲区的指针,而不是一个字符(本质上是一个数字)。

答案很简单,而不是传递c给,而是write()传递 的地址c,即。&c.

于 2012-05-26T22:17:28.007 回答