说我有
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/