使用具有多个过程的管道连续写入和读取

时间:2019-01-21 06:11:08

标签: c linux operating-system

我的代码包含两个过程。父进程连续从stdin读取单个字符并将其写入管道(无需按Enter)。子进程从管道读取并写入stdout。我的父进程已成功写入管道,但子进程未打印输出。

子进程不打印输出的原因是因为它停留在父进程的while循环中,并且从不进入子进程的while循环。

当我在Mac上使用“活动监视器”强制退出父进程时,我输入的内容实际上会打印出来。随后是“杀死:9”

是否有一种方法可以修复我的代码,以便每次Parent(Input)收到一个字符时,Child(Output)会打印出每个字符而不会陷入父进程的while循环中?

char input() {
  char input = getchar();
  return input;
}

int main(void) {

  int inputOutputFd[2];
  pid_t childpid = 0;

  system("/bin/stty raw igncr -echo");

  if(pipe(inputOutputFd) < 0) {
    perror("Failed to create pipe");
    return 1;
  }

  if((childpid = fork()) == -1) {
    perror("Failed to fork input child");
    return 1;
  }

//parent's code -INPUT
  if (childpid > 0) {
    close(inputOutputFd[0]);
    printf("Please enter a word or phrase");

    while(1) {
      char inputChar = input();
      write(inputOutputFd[1], &inputChar, sizeof(inputChar));
    }

    close(inputOutputFd[1]);
    wait(NULL);

  } else { 

//child -OUTPUT
    char outputChar;
    close(inputOutputFd[1]);
    while (read(inputOutputFd[0], &outputChar, sizeof(outputChar)) > 0) 
    {
      printf("%c", outputChar);
      fflush(stdin);
    }
  } //END OF IF-ELSE LOOP
}//END MAIN

1 个答案:

答案 0 :(得分:2)

一切正常,没有卡住或任何东西,直到您期望在控制台中输出。该错误在这两行中:

  printf("%c", outputChar);
  fflush(stdin);

stdin标准输入。您正在写入标准输出

  printf("%c", outputChar);
  fflush(stdout);

为我工作。