javascript - process.stdin 流的可读事件和数据事件有什么区别?

标签 javascript node.js stream buffer stdin

说我有

process.stdin.setEncoding('utf8');
var myString = '';

两者有什么区别

process.stdin.on('readable', function() {
  myString += process.stdin.read();
});

process.stdin.on('data', function(chunk) {
  myString += chunk;
});

如果输入字符串在标准输入结束后相同,他们会给我相同的 myString

每种方法的最佳做法是什么?谢谢

最佳答案

它们是两个不同的 API,允许您访问相同的数据 block 流。 'readable' API 作为“Streams 2”的一部分在 Node 0.10.0 中引入,因此如果您搜索它,它应该会有所帮助。问题的核心在于 '可读' 接口(interface)允许更简单的数据管理和缓冲。

'data' 示例使用 block 调用您的函数,您别无选择,只能处理它,否则它将永远丢失。在 '可读' 示例中,该函数告诉您数据可用,但您可以随时读取它。这允许底层系统知道您是否已经处理过数据,因此支持称为背压的概念非常简单。

例如,在网络流中,如果客户端通过 TCP 连接向服务器发送数据并且服务器非常繁忙,它将接收 可读 事件,但它可以选择等待读取数据,直到它真正拥有处理数据的资源。通过不读取数据,流将对其进行缓冲,当缓冲区接近最大大小时,流将停止从操作系统读取数据包以避免占用过多的 RAM。然后操作系统将开始丢弃数据包,由于数据包被丢弃,正在发送数据的客户端将降低发送数据的速度以尝试减少丢弃的数据包。

旧的流“V1”实现在技术上都支持这一切,但要做到这一点要困难得多。

所以基本上,如果您期待大量数据,使用“可读”或将流设计为管道是一个非常好的主意,但如果您只是从终端读取数据位,那么您很可能会看到零差异。

关于javascript - process.stdin 流的可读事件和数据事件有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26174308/

相关文章:

javascript - 如何在 PugJS 的路由器中触发 onclick 功能?

Java Stream 关​​闭方法的不明确行为

Node.js - 可读流如何对仍在写入的文件使用react?

javascript - Ionic 两侧菜单模式在添加更多内容时不会自动滚动

javascript - Bootstrap Datepicker定位不起作用

c++ - 无法在 Electron 中获取 displayName

javascript - 使用 NodeJS 获取目录列表内容

c++ - 编写带有标题的表的 ofstream/fstream 对象的高效且干净的方法

javascript - D3 : Lag update on force layout links when dataset changes

javascript - 如何在noty中添加事件onClick以用于jQuery中的通知?