您的位置:MYSQL中文网 > Node.js Stream(流)

Node.js Stream(流)

2023-10-04 06:30 Node.js教程

 Node.js Stream(流)

Node.js中的streams基于事件。

所有这些stream类都继承自基本抽象Stream类,它继承自EventEmitter。

var stream = require("stream"); 
var EventEmitter = require("events").EventEmitter; 

console.log(new stream.Stream() instanceof EventEmitter); // true 
console.log(new stream.Readable({}) instanceof stream.Stream); // true 
console.log(new stream.Writable({}) instanceof stream.Stream); // true 
console.log(new stream.Duplex({}) instanceof stream.Stream); // true 
console.log(new stream.Transform({}) instanceof stream.Stream); // true 

上面的代码生成以下结果。

stream类

管道

所有流都支持使用管道成员函数可以完成的管道操作。

此函数称为管道,因为它模拟命令行管道操作符的行为,例如cat file.txt | grep yourtest

fs 核心模块提供了用于从文件创建可读或可写流的实用程序函数。

以下代码显示如何将文件从文件系统流式传输到用户控制台。

var fs = require("fs"); 
// Create readable stream 
var readableStream = fs.createReadStream("./a.js"); 
// Pipe it to stdout 
readableStream.pipe(process.stdout); 

你还可以使用pipe链接多个stream。

以下代码从文件创建可读取流,通过zip变换流管道,然后将其管道到可写文件流。

这将在文件系统上创建一个zip文件。

var fs = require("fs"); 
var gzip = require("zlib").createGzip(); 

var inp = fs.createReadStream("a.js"); 
var out = fs.createWriteStream("a.js.gz"); 

// Pipe chain 
inp.pipe(gzip).pipe(out); 

Node.js中的steams基于事件。



阅读全文
以上是MYSQL中文网为你收集整理的 Node.js Stream(流)全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 MYSQL中文网 mysqlcn.com 版权所有 联系我们
桂ICP备12005667号-29 Powered by CMS