我有下面的C代码。 孩子用于运行test3,其代码将在下面。 父级用于将数据传递给子级,子级将重定向到test3的STDIN。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>
int main(int argc, char *argv[]) {
int fd[2];
char buf[] = "HELLO WORLD!";
if(pipe(fd)){
perror("pipe");
return -1;
}
switch(fork()){
case -1:
perror("fork");
return -1;
case 0:
// child
close(fd[1]);
dup2(fd[0], STDIN_FILENO);
close(fd[0]);
system("./test3");
default:
// parent
close(fd[0]);
FILE* stream = fdopen(fd[1],"w");
if(stream == NULL){ // error checking
printf("Error creating a file\n");
printf("%s\n", strerror(errno));
return -1;
}
// write data to pipe
fwrite(buf, 1,6,stream);
close(fd[1]);
fclose(stream);
}
printf("END~\n");
return 0;
}
这是test3代码:
#include <stdio.h>
int main(){
char n[1000];
scanf("%s",n);
printf("%s\n",n);
}
我的问题是父代码中的fdopen
返回带Bad file descriptor error
的NULL,我无法弄清楚原因。任何人都可以帮忙吗?
提前致谢。
答案 0 :(得分:2)
错误实际上来自孩子,而不是父母。在孩子使用系统调用运行test3
之后,它会进入default:
情况,尝试fdopen
已关闭的文件描述符。系统调用后添加break;
,错误就会消失。
第二个问题是父级中的close(fd[1])
,它在刷新您使用fwrite
编写的数据之前从FILE指针下关闭文件描述符。要么在fflush(stream);
之前拨打close
,要么只删除close
,因为fclose
会关闭文件描述符。