如何允许两个并发进程进行通信?

我有两个独立的进程:一个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程序在处理输入之前等待第一个程序完成.

有没有人对这个问题的解决方案有任何想法,建议或见解?先感谢您!

解决方法

管道应该没问题;您只需要控制何时刷新C程序的输出以使其逐渐可用于perl脚本.您可以使用 fflush()在C程序中执行此操作,这将强制推送C程序中的缓冲区,以便perl程序可以读取它.

管道没有固有的东西会导致perl程序在处理输出之前等待C程序完成写入.编写perl程序,以便一次处理一行STDIN:

while ($line = <STDIN>) { ... }

<>在这个上下文中从STDIN中读取一行,但是如果没有可用的那么它将阻塞直到一行.从C程序调用fflush()会使这种情况发生.

看一下Wikipedia article on Pipelines.实现部分简要介绍了如何缓冲管道,这可以帮助您了解流程的通信方式.管道允许进程之间的并发,并且管道的读取和写入过程由调度程序管理,就像其他进程一样.你的问题在于缓冲.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...