Fflush不会写缓冲文本

时间:2016-12-13 20:07:57

标签: c io pipe buffer fflush

我尝试使用以下代码将2D表格打印到终端:

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <termios.h>
#include <sys/wait.h>

char getch()
{
    char ch;
    struct termios old, new;
    tcgetattr(0, &old); // grab old terminal i/o settings
    new = old; // new settings = old settings
    new.c_lflag &= ~ICANON; // disable buffered i/o
    new.c_lflag &= ~ECHO; //set echo mode
    tcsetattr(0, TCSANOW, &new); // use these new terminal i/o settings now
    ch = getchar();
    tcsetattr(0, TCSANOW, &old); //restore old settings
    return ch;
}

void readPBM(char *output)
{
    char tmp[1024];

    int fd[2] = {0,0};
    int pid;

    //Open the pipe for inter-process communication
    pipe(&fd[0]);

    //Fork and test if we are child or parent process
    pid = fork();
    if(pid) //Parent process
    {
        wait(NULL); //Wait for child's end
        close(fd[1]);//Close pipe's write stream
        close(0);//Close stdin
        dup(fd[0]);//Duplicate stdout
        close(fd[0]);//Close old stdout

        strcpy(output, "");// Init output at 0
        while(fgets(tmp, 1024, stdin) != NULL) //Put remaining entry in output
        {
            strcat(output, tmp);
        }
    }
    else if(pid == 0) //Child process
    {
        close(fd[0]);//Close pipe's read stream
        close(1);//Close stdout
        dup(fd[1]);//Duplicate stdin
        close(fd[1]);//Close old stdin

        printf("A random string ...\n");
    }
    else //Print error if fork failed
    {
        printf("Error creating a new process");
        exit(EXIT_FAILURE);
    }
}

int main(int argc, char *argv[])
{
    int i, j;

    char *str = NULL;
    char c;

    str = malloc(512 * sizeof(char*));

    readPBM(str);

    printf("%s", str);
    fflush(stdout);
    c = getch();
}

我有UNIX implementation of getch()

我的问题是我的程序正在等待打印表的输入。我尝试fflush(stdout)并使用ICANON禁用终端缓冲,但它仍无效。

PS:它没有用getchar,scanf,......

编辑:所以我想到了这个最小的例子;它似乎与管道有关。

1 个答案:

答案 0 :(得分:0)

  

我的问题是我的程序正在等待输入以打印表格。

这是因为您忘记了子进程完成工作后的终止,因此在将A random string ...打印到管道之后,它将继续,从readPBM()返回并最终执行c = getch()main()的末尾。补救措施是在exit(0)块的末尾调用if(pid == 0) //Child process

相关问题