我有以下代码:
#include<stdio.h>
FILE *f,*stream1,*stream2,*stream3,*stream4;
int main()
{
int pfd[2];
int pfd1[2];
int pfd2[2];
int pid1;
int pid2;
pipe(pfd);
pipe(pfd1);
pipe(pfd2);
f=fopen("date","r");
pid1=fork();
if(pid1==0){
close(pfd[1]);
stream2=fdopen(pfd[0],"r");
char c;
int rd=fread(&c,sizeof(char),1,stream2);
while(rd!=0){
printf("%c",c);
rd=fread(&c,sizeof(char),1,stream2);
}
close(pfd[0]);
exit(0);
}
pid2=fork();
if(pid2==0){
printf("second process\n");
exit(0);
}
if(pid1>0&&pid2>0){
close(pfd[0]);
stream1=fdopen(pfd[1],"w");
while(!feof(f)){
char c;
fscanf(f,"%c",&c);
if(feof(f)) break;
fwrite(&c,sizeof(char),1,stream1);
}
close(pfd[1]);
exit(0);
}
}
此代码从文件中获取一些输入并将其显示在 child1 中。
问题是每当我想在父进程中关闭 pfd[1]
时,child1 (pid1
) 中的输出不会显示。为什么会这样?如果我不关闭 pfd[1]
,它会正常运行。
编辑:我解决了。问题是我使用了 fread、fwrite 而不是读写。有了这个,一切都按我想要的方式运行。
最佳答案
有两个问题:
1) 您正在使用 fdopen
和 fwrite
而不是使用 write
写入管道。
这是可能的,但是 fwrite
会在内部调用 write
之前缓冲数据。
当您调用 fclose(stream1)
时,fclose
函数将首先使用 write()
写入所有缓冲数据,然后调用 关闭(pfd[1])
。
但是,如果您直接调用 close(pfd[1])
,则缓冲数据不会写入管道。
2) 当程序完成时,子进程通常也会被杀死。
在使用 fork
创建的所有子进程也完成之前,不要离开 main
函数。 (使用 return
或 exit()
都没有关系)。
使用waitpid
或wait4
函数等待子进程完成。
我在我的电脑上编译了这个程序:只有在解决两个问题时我才能得到想要的结果。
关于c - C 中的 Linux 管道,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46181803/