我如何从child_process.execFile实时获得结果?

时间:2019-04-26 05:23:24

标签: node.js child-process

我想通过运行Node.js从基于C的二进制实时获取数据。我知道Node.js可以使用child_process模块​​运行可执行二进制文件。

所以我创建了一个简单的C / Node.js应用程序,如下所示:

// It will be compiled to a.out and run by below Node.js code
#include <stdio.h>

int main() {
    int i=0;
    for (i=0; i<10; i++) {
        printf("%d\n", i);
        sleep(1);
    }
}
var spawn = require('child_process').spawn;

var cmd = spawn('./a.out');

cmd.stdout.on('data', function(data) {
    console.log('stdout : ' + data);
});

cmd.stderr.on('data', function(data) {
    console.log('stderr : ' + data);
});

cmd.stdout.on('end', function(data) {
    console.log('end');
});

还有我的期望:

00:00] 0
00:01] 1
00:02] 2
...
00:09] 9
00:10] 10

但我看到了

00:10] 0
1
2
...
9
10

看起来所有来自二进制文件的标准输出都将存储到缓冲区,并且在二进制文件终止之后,将显示所有缓冲区数据。 我希望cmd.stdout.on('data',callback)将运行10次,但仅运行1次。

但是我想得到像流一样的结果。 如何获取流之类的数据,或者如何实时按行获取数据?

1 个答案:

答案 0 :(得分:0)

  

默认情况下,通常将stdout缓冲到写入换行符为止。但是,如果stdout不是tty(在child_process.spawn()中就是这种情况),则无论换行符如何,所有输出都会被缓冲。您可以通过执行setbuf(stdout, NULL)完全禁用stdout缓冲。

我尝试了以下方法,它有效。

#include <stdio.h>

int main() {

    setbuf(stdout, NULL);

    int i=0;
    for (i=0; i<10; i++) {
        printf("%d\n", i);
        sleep(1);
    }
}

Ref:thisthis