FIFO 管道仅在写入端关闭后读取

FIFO pipe only reads after write end has closed

我正在尝试在 python 文件和 C 文件之间创建一个 FIFO 管道,但问题是当从 C 文件读取输入时,getline 阻塞直到写入器结束(在python 文件)关闭。

C文件:

char fifo_emg[] = "emg";
mkfifo(fifo_emg, S_IRWXU);

int fd_emg = open(fifo_emg, O_RDONLY);
FILE* fp = fdopen(fd_emg, "r");

char *line = NULL;
size_t len = 0;
ssize_t _read;
printf("Both ends open. Reading commands...\n");
while ((_read = getline(&line, &len, fp)) != -1) {
    printf("Comamnd: %s", line);
}   

Python 文件:

fifo = open("emg", "w");

while 1:
    line = raw_input("ENTER COMMAND: ")
    if line[0] == '!':
        break
    else:
        fifo.write(line + '\n')

fifo.close()

当我 运行 两者时,我希望 C 文件的输出去 "Command: foo" 一旦通过 python 输入输入。 但是数据只有在调用fifo.close()时才读入,而且是一次性读入。这并不是很有帮助,因为我想要源源不断的命令。

正如 immibis 在评论中所说,fifo.flush() 解决了我的问题!

您的问题来自缓冲区。 FIFO 默认使用块缓冲区。因此,在 python 中的 fifo 的写入缓冲区已满之前,c 程序不会读取任何内容。有两种方法可以改变这种行为:

  • 指定缓冲模式:

有三种缓冲模式:

  1. 块缓冲区(默认)
  2. 行缓冲区
  3. 根本没有缓冲区

这里满足你需求的是line buffer,所以用fifo = open("emg", "w", 1);代替fifo = open("emg", "w");就可以解决。 这里的数字 1 代替行缓冲区。 python doc

  • 另一种方法是强制刷新缓冲区,在写操作后使用fifo.flush

是的..强制冲洗将解决问题。