Node.js 调用可执行文件时的 stdout 缓冲区问题

Node.js 调用其他语言编译出来的可执行文件是非常常见的场景。

但只要涉及到「实时输出」,一个经典的坑是:缓冲区。

一、swift+node错误示例

swift

swift 复制代码
import Darwin

print("Hello")
sleep(2)
print("World")

正常输出

复制代码
Hello
(停 2 秒)
World

打包为可执行文件

shell 复制代码
swiftc helloworld.swift -o helloworld

node调用

js 复制代码
import { exec } from 'child_process';

exec('./helloworld', (err, stdout) => {
  console.log(stdout);
});

结果,2秒后全部输出,而不是先输出Hello等2秒才到World。

复制代码
(停 2 秒)
Hello
World

二、修复

swift关闭缓冲

swift 复制代码
import Darwin

setbuf(stdout, nil) // 关闭缓冲

print("Hello")
sleep(2)
print("World")

node调用

之前的exec适合一次性调用。可以改为spawn更适配流式实时。

js 复制代码
import { spawn } from 'child_process';

const p = spawn('./helloworld');

p.stdout.on('data', data => {
  process.stdout.write(data);
});

另外一种正确写法

js 复制代码
import { spawn } from 'child_process';

spawn('./helloworld', {
  stdio: 'inherit'
});

输出结果,表现正常

复制代码
Hello
(停 2 秒)
World
相关推荐
IT_陈寒1 小时前
React中useEffect依赖项这个坑我居然踩了三天
前端·人工智能·后端
qq4356947011 小时前
Vue04
前端·vue.js
我是真菜2 小时前
彻底理解js中的深浅拷贝
前端·javascript
江畔柳前堤2 小时前
github实战指南07-CLI 与高级技巧
前端·人工智能·chrome·深度学习·github·caffe·issue
weixin_571667412 小时前
[解决] Node.js 安装后 命令找不到
node.js
kisdiem3 小时前
ReAct:让大模型一边推理,一边行动
前端·react.js·前端框架
西部荒野子3 小时前
JS 如何跑进两个原生世界
前端
RANxy3 小时前
AntV 入门系列第一篇:从零开始的数据可视化之旅
前端
小小小小宇4 小时前
前端 WebRTC 全解析与应用
前端
华玥4 小时前
优化滚动列表,使用虚拟滚动
前端