我有两个独立的进程:一个C程序,输出逗号分隔值,后跟每秒一个换行符;一个Perl程序,接受数据(格式相同)并处理这些数据.
C程序输出(通过printf)值如下:
1,2,3,4,5,6 7,8,9,10,11,12 ...
Perl程序位于一个无限循环中,等待STDIN的行,以便处理这些数据:
while ($line = <STDIN>) { chomp($line) # Line should now read "1,6" # Process data }
我希望这两个过程实时通信.标准bash管道不起作用(例如process1 | process2),因为Perl程序在处理输入之前等待第一个程序完成.
有没有人对这个问题的解决方案有任何想法,建议或见解?先感谢您!
@R_301_323@
管道应该没问题;您只需要控制何时刷新C程序的输出以使其逐渐可用于perl脚本.您可以使用
fflush()
在C程序中执行此操作,这将强制推送C程序中的缓冲区,以便perl程序可以读取它.
管道没有固有的东西会导致perl程序在处理输出之前等待C程序完成写入.编写perl程序,以便一次处理一行STDIN:
while ($line = <STDIN>) { ... }
<>在这个上下文中从STDIN中读取一行,但是如果没有可用的那么它将阻塞直到一行.从C程序调用fflush()会使这种情况发生.
看一下Wikipedia article on Pipelines.实现部分简要介绍了如何缓冲管道,这可以帮助您了解流程的通信方式.管道允许进程之间的并发,并且管道的读取和写入过程由调度程序管理,就像其他进程一样.你的问题在于缓冲.