这是我的代码
#include <iostream>
#include <string>
#include <sys/wait.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
#include <vector>
#include <sstream>
#include <stdio.h>
using namespace std;
int main() {
int pipe_A[2];
int pipe_B[2];
pipe(pipe_A);
pipe(pipe_B);
pid_t pid_A, pid_B, pid_C;
if (!(pid_A = fork())) {
dup2(pipe_A[1], 1); /* redirect standard output to pipe_A write end */
system("./data");
exit(0);
}
if (!(pid_B = fork())) {
dup2(pipe_A[0], 0); /* redirect standard input to pipe_A read end */
dup2(pipe_B[1], 1); /* redirect standard output to pipe_B write end */
system("grep 5");
exit(0);
}
if (!(pid_C = fork())) {
dup2(pipe_B[0], 0); /* redirect standard input to pipe_B read end */
system("grep 2");
exit(0);
}
return 0;
}其中"./data“是我的测试样本,它执行以下操作:
for(int i=0;i<100;i++){
cout<<i<<endl;
}我试着根据这个link构建一个管道:
显然我的程序不能工作。在我运行我的程序之后,将有两个进程永远执行pipe_wait (我在系统监视器中看到了)。似乎有一些管道应该关闭。我该怎么解决它呢?
发布于 2012-01-27 03:44:26
每个子进程都有自己的父进程文件描述符的副本。而dup2又创建了另一个副本。管道的读取端将不会返回EOF,直到写入端的所有副本都关闭。
因此,在每次调用fork + dup2之后,继续close pipe_A、pipe_A1、pipe_B和pipe_B1中的所有四个。
在派生所有子对象之后,还要在父对象中关闭它们。(在您的示例中,这并不是绝对必要的,因为它们将在main()返回时自动关闭。但不管怎样,为了干净我还是会这么做的。)
https://stackoverflow.com/questions/9024099
复制相似问题