我正在尝试从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),然后让子级继承这些描述符并以这种方式将数据相互传递。

08-19 13:22