我正面临标题所说的确切问题。
CODE
pid_t childpid;
int childfdRead, childfdWrite; // file descriptors for childs
int parentfdsRead[numWorker], parentfdsWrite[numWorker]; // file descriptors for parent
// store the fifo filenames
char *childPipeNameRead[numWorker];
char *childPipeNameWrite[numWorker];
// helper string to construct fifo filenames
char *suffix = (char*)malloc(20*sizeof(char));
char *fifoname = (char*)malloc(20*sizeof(char));
for(i = 0; i < numWorker; i++){
// Fifo filename structure read
sprintf(fifoname, "%s", PATH);
sprintf(suffix, "_childRead%d", i);
childPipeNameRead[i] = strdup(strcat(fifoname, suffix));
mkfifo(childPipeNameRead[i], 0666);
// Fifo filename structure write
sprintf(fifoname, "%s", PATH);
sprintf(suffix, "_childWrite%d", i);
childPipeNameWrite[i] = strdup(strcat(fifoname, suffix));
mkfifo(childPipeNameWrite[i], 0666);
childpid = fork();
if(childpid < 0){
perror("fork\n");
}
else if(childpid == 0){
// Open read and write pipes on childs.
if((childfdRead = open(childPipeNameRead[i], O_RDONLY | O_NONBLOCK)) < 0)
perror("child pipe:");
printf("Child with id %d opened pipe with name %s\n", getpid(), childPipeNameRead[i]);
if((childfdWrite = open(childPipeNameWrite[i], O_WRONLY)) < 0)
perror("child pipe:");
printf("Child with id %d opened pipe with name %s\n", getpid(), childPipeNameWrite[i]);
break;
}
else{
// Open read and write pipes for each child in the parent process.
if((parentfdsRead[i] = open(childPipeNameRead[i], O_RDONLY | O_NONBLOCK)) < 0)
perror("parent pipe:");
printf("Parent with id %d opened pipe with name %s\n", getpid(), childPipeNameRead[i]);
if((parentfdsWrite[i] = open(childPipeNameWrite[i], O_WRONLY)) < 0)
perror("parent pipe:");
printf("Parent with id %d opened pipe with name %s\n", getpid(), childPipeNameWrite[i]);
}
}
程序在父级和一个子级打开其读取管道后挂起(父级只打开其中一个)。这是正常的行为吗?我期待它打开所有管道,因为我对父母和孩子使用O_RDONLY | O_NONBLOCK
。
答案 0 :(得分:1)
问题是您打开childPipeNameRead[i]
以阅读两个子进程和父进程。同样,你打开childPipeNameWrite[i]
来写两个进程。
您需要在其中一个过程中执行相反的操作。