许多运行时库(例如,我知道libc会这样做,如果其他人也这样做,也不会感到惊讶)默认情况下会缓冲其输出, 除非
输出到终端。当处理许多行时(例如,在正常管道中),这极大地提高了数据处理的效率,但是当信息量很少时,它会带来很多伤害。如果您有权访问子流程的源,那么绝对最好通过关闭缓冲或添加刷新来更新代码。
但这并不总是可能的,尤其是在处理第三方代码时。在这种情况下,我所知道的最佳 其他
修复方法是使用Expect等工具欺骗子流程。在内部,Expect知道如何伪装成终端(在Unix上使用pty和在Windows上使用令人讨厌的黑客手段),从而欺骗其他程序以关闭(或至少减少)它们的缓冲。对于Expect,有一个脚本-
unbuffer-使它专门针对这种使用。(通常,它不仅可以处理不规则的缓冲,还可以做很多事情,但这还是最好的解决方法。)



