我是线程新手,所以我觉得好像我错过了一个明显的观点,但是我找不到与此主题有关的以前的问题。同时阅读stdin并在python中写入标准输出
我想写一个程序写入stdin并读取一个c程序的标准输出。这是主程序中的代码。
from subprocess import Popen, PIPE
from threading import Thread
from Queue import Queue, Empty
from os import getcwd
import time
import random
chatter = Queue(maxsize=10) # Queue of strings to be sent to the program
class Chatter():
def stream_talker(self, identifier, stream):
while True:
if not chatter.empty():
self.proc.stdin.write(chatter.get(True, 1))
def stream_watcher(self, identifier, stream):
while True:
for line in stream:
print line
def main(self):
self.proc = Popen(getcwd() + '/main', stdout=PIPE, stdin=PIPE)
Thread(target=self.stream_talker, name='stdin-talker', args=('STDIN', self.proc.stdin)).start()
Thread(target=self.stream_watcher, name='stdout-listening', args=('STDOUT', self.proc.stdout)).start()
while True:
chat = raw_input('Enter chatter: ')
if len(chat) > 0:
chatter.put(chat)
if __name__ == '__main__':
chatt = Chatter()
chatt.main()
这里是它调用的main.c程序。
#include <stdio.h>
#include <stdlib.h>
int main(){
while (1){
int bytes_read;
size_t nbytes = 100;
char *my_string;
my_string = (char *)malloc(nbytes + 1);
bytes_read = getline (&my_string, &nbytes, stdin);
if (bytes_read == -1)
{
puts ("ERROR!");
}
else{
puts (my_string);
}
free(my_string);
}
return 0;
}
目前的问题是,虽然它会运行,但stdout永远不会被打印。
您是否尝试冲洗缓冲区(两端)? – 2015-02-11 17:50:16
1.你使用'stream_talker'两次。你也想运行'stream_watcher'。 2. [你应该强制行缓冲](http://stackoverflow.com/q/20503671/4279)3.它[足以启动一个线程来同时提供输入和读取输出](http: //stackoverflow.com/q/28291847/4279) – jfs 2015-02-11 18:16:49
@JFSebastian我正在寻找这两个答案,现在感谢您的链接。 – 2015-02-11 18:32:48