我有这个代码:
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);
}
希望这可以帮助其他人不必在桌子上撞头四天!并感谢所有抽空回答的人。