我正在尝试从Child1向Child3发送一个字符串“ Hi”,这是两个同级进程。该代码运行,但是我没有收到Child3中Child1的输入。
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/wait.h>
#include <fcntl.h>
#include <sys/stat.h>
#define MSGSIZE 1024
int main (int argc, char *argv[]){
int fd;
char * myfifo = "/desktop/myfifo";
char l[MSGSIZE];
pid_t child1, child3;
mkfifo(myfifo, 0666);
child1 = fork();
if (child1 == 0) {
printf("I am Child 1: %d \n", (int)getpid());
fd = open(myfifo, O_WRONLY);
write(fd, "Hi", MSGSIZE);
close(fd);
}
else {
if (child1 > 0 ) {
printf("I am parent: %d \n", (int)getpid());
wait(0);
}
child3 = fork();
if (child3 == 0) {
printf("I am Child 3: %d \n", (int)getpid());
fd = open(myfifo, O_RDONLY);
read(fd, l, MSGSIZE);
printf("Received: %s \n", l);
close(fd);
}
}
wait(0);
unlink(myfifo);
return 0;
}
希望有人能指出正确的方向。
最佳答案
除非您要进行非阻塞IO,否则打开FIFO的一端将一直阻塞,直到另一端也被打开为止。因此child1
在其open(2)
调用中阻塞,直到child3
打开管道的末端。但是,在派生wait(2)
之前,您还要在父进程中调用child3
。
因此,您将陷入僵局:父级正在等待child1
派生child3
,但是child1
正在等待child3
打开管道的另一端。
您可以通过至少两种方式解决此问题。首先,在派生第二个子进程之后,只需放置wait(2)
调用即可。另一种方法是在父进程中创建一个pipe(2)
,然后让子级继承这些描述符并以这种方式将数据相互传递。