标准输出和标准错误输出顺序错误-缓冲情况微不足道

问题描述

所以我在将过程写入stdout和stderr时遇到问题。一些stderr日志显示得太早-在应该首先显示的stdout行之前。现在,这似乎是明显的缓冲问题。但是,由于我如何重定向stdio,我认为情况并非如此。这正是我的情况:

我有python脚本(父级)启动了像这样的nodejs脚本(子级)

  p1 = subprocess.Popen(
        args,stdout=subprocess.PIPE,cwd=working_dir,stderr=subprocess.STDOUT,env=env)

现在,子级(nodejs)产生了子级(c ++程序),如下所示:

params.stdio = [process.stdin,process.stdout,process.stderr];
var childRet = spawnSync(path,args,params);

顺序错误的日志全部来自单线程的孙c ++程序。现在,对于AFAIU而言,此问题已不再是一个微不足道的缓冲问题,因为孙子的stdout和stderr都直接进入了孩子的stdout和stderr。现在,将child的stdout放入管道中-该管道可以缓冲-但stderr重定向到stdout,因此它应该以相同的管道结束,并因此以正确的顺序进入相同的缓冲区。

现在为什么输出显示顺序错误?我不知道的进程之间有缓冲吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...