我正在尝试在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文件的输出 “命令:foo” 一旦通过python输入进入。 但是,只有在调用fifo.close()时才读入数据,并且只是一次性读取数据。这不是很有用,因为我想要一个恒定的命令流。
答案 0 :(得分:2)
您的问题来自缓冲区。 FIFO默认使用块缓冲区。因此,在python中的fifo的写缓冲区已满之前,c程序将不会读取任何内容。并且有两种方法可以改变这种行为:
有三种缓冲模式:
这里满足您的需求的是行缓冲,因此使用fifo = open("emg", "w", 1);
代替fifo = open("emg", "w");
将会修复。
这里的数字1代替行缓冲区。 python doc
fifo.flush
。答案 1 :(得分:1)
是..强制刷新将解决问题。
答案 2 :(得分:0)
正如immibis在评论中所说,fifo.flush()解决了我的问题!