[Node.js]Stream

摘要

Stream是一个抽象接口,Node中有很多对象实现了这个接口。例如,对http服务器发送请求的request对象就是一个Stream。

Stream

Stream有四种流类型:

  1. Readable:可读操作。
  2. Writable:可写操作。
  3. Duplex:可读写操作。
  4. Transform:操作被写入数据,然后读出结果。

所有Stream对象都是EventEmitter的实例,常用的事件:

  1. data:当有数据可读时触发。
  2. end:没有更多的数据可读时触发。
  3. error:在接收和写入过程中发生错误时触发。
  4. finish:所有数据已被写入到底层系统时触发。

读取

创建stream.txt文件,内容如下:

Hello Stream world......

创建stream.js文件,代码如下:

//引入fs模块。
var fs=require("fs");
//接收数据变量
var data=‘‘;
//创建可读流
var readerStream=fs.createReadStream("stream.txt");
//设置编码utf8
readerStream.setEncoding("UTF8");
//处理流事件——>data,end,error
readerStream.on(‘data‘,function(chunk){
    data+=chunk;
});
readerStream.on("end",function(){
    console.log(data);
});
readerStream.on("error",function(err){
    console.log(err.stack);
});
console.log("程序执行Over");

执行

创建write.js

//引入fs
var fs=require("fs");
var data="hello my stream world.";
//创建一个可以写入的流。写入到文件output.txt中
var writeStream=fs.createWriteStream("output.txt");
//使用utf8 写入文件
writeStream.write(data,"UTF8");
//标记文件末尾
writeStream.end();
//处理流事件
writeStream.on("finish",function(){
    console.log("写入完成");
});
writeStream.on("error",function(err){
    console.log(err.stack);
});
console.log("程序执行完毕");

执行

这时,在output.txt中就可以看到内容了。

管道流

管道提供了一个输出流到输入流的机制。通常用于从一个流中获取数据并将数据传递到另外一个流中。

一个例子

var fs=require("fs");
//创建一个可读流
var readerStream=fs.createReadStream("stream.txt");
//创建一个可写流
var writeStream=fs.createWriteStream("output.txt");
//管道读写操作
//读取stream.txt文件内容,并将内容写入到output.txt文件中。
readerStream.pipe(writeStream);
console.log("程序执行完毕");

链式流

链式是通过连接输出流到另外一个流并创建多个对个流操作链的机制。链式流一般用于管道操作。

一个例子

用管道和链式拉i压缩和解压缩文件

创建compress.js

var fs=require("fs");
var zlib=require("zlib");
//压缩stream.txt 文件 stream.txt.gz
fs.createReadStream("stream.txt").pipe(zlib.createGzip()).pipe(fs.createWriteStream("stream.txt.gz"));
console.log("文件压缩完成");

学习资料

http://www.runoob.com/nodejs/nodejs-stream.html

时间: 2024-07-29 00:34:20

[Node.js]Stream的相关文章

Node.js Stream(流)

Stream 是一个抽象接口,Node 中有很多对象实现了这个接口.例如,对http 服务器发起请求的request 对象就是一个 Stream,还有stdout(标准输出). Node.js,Stream 有四种流类型: Readable - 可读操作. Writable - 可写操作. Duplex - 可读可写操作. Transform - 操作被写入数据,然后读出结果. 所有的 Stream 对象都是 EventEmitter 的实例.常用的事件有: data - 当有数据可读时触发.

node.js Stream Buffer FsPromise

Stream: 类似这样:a.pipe(b).pipe(c); 我想写一个b.所以: var rs=new (require('stream').Readable)(); var ws=new (require('stream').Writable)(); rs._read=function(){ this.push('send a msn for the first time'); this.push('send a msn for the second time'); this.push(n

Node.js Stream - 实战篇

邹斌 ·2016-07-22 11:04 背景 前面两篇(基础篇和进阶篇)主要介绍流的基本用法和原理,本篇从应用的角度,介绍如何使用管道进行程序设计,主要内容包括: 管道的概念 Browserify的管道设计 Gulp的管道设计 两种管道设计模式比较 实例 Pipeline 所谓“管道”,指的是通过a.pipe(b)的形式连接起来的多个Stream对象的组合. 假如现在有两个Transform:bold和red,分别可将文本流中某些关键字加粗和飘红.可以按下面的方式对文本同时加粗和飘红: //

Node.js——Stream

介绍 文件流:我们一般对大一点的文件实现stream的方式进行操作 http:显然http.createServer创建过程中的IncomingMessage实现了可读流的接口,ServerResponse实现了可写流的借口 文件流 写入流的close事件,必须通过ws.end() 方法来调用 文件的默认是flags是w,这是覆盖操作,追加的话是a var fs = require('fs') var rs = fs.createReadStream('./a.txt') var ws = fs

Node.js 教程

Node.js 教程nodejs简单的说 Node.js 就是运行在服务端的 JavaScript.Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台.Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎,V8引擎执行Javascript的速度非常快,性能非常好.谁适合阅读本教程?如果你是一个前端程序员,你不懂得像PHP.Python或Ruby等动态编程语言,然后你想创建自己的服务,那么Node.js是一个非常好的选择.No

Node.js Stream-基础篇

Node.js Stream - 基础篇 邹斌 ·2016-07-08 11:51 背景 在构建较复杂的系统时,通常将其拆解为功能独立的若干部分.这些部分的接口遵循一定的规范,通过某种方式相连,以共同完成较复杂的任务.譬如,shell通过管道|连接各部分,其输入输出的规范是文本流. 在Node.js中,内置的Stream模块也实现了类似功能,各部分通过.pipe()连接. 鉴于目前国内系统性介绍Stream的文章较少,而越来越多的开源工具都使用了Stream,本系列文章将从以下几方面来介绍相关内

清晰地去看 Node.js(二)

比较缓冲器拷贝缓冲区 路由指的就是我们要针对不同的URL有不同的处理方式,例如处理/start的业务逻辑和处理/upload模块 的业务:逻辑就 是不一致的. Node.js 模块系统:http://www.shouce.ren/api/view/a/3470 代码区: /** * 比较缓冲器 * buf1.compare(buf2); */ var buffer1 = new Buffer('ABC'); var buffer2 = new Buffer('ABCD'); var result

Node.js 【Stream之笔记】

从Node.js API文档中可知, 'A stream is an abstract interface implemented by various objects in Node. For example a request to an HTTP server is a stream, as is stdout. Streams are readable, writable, or both. All streams are instances of EventEmitter.''流是很多

Node.js开发入门—Stream用法详解

Stream是Node.js中非常重要的一个模块,应用广泛.一个流是一个具备了可读.可写或既可读又可写能力的接口,通过这些接口,我们可以和磁盘文件.套接字.HTTP请求来交互,实现数据从一个地方流动到另一个地方的功能. 所有的流都实现了EventEmitter的接口,具备事件能力,通过发射事件来反馈流的状态.比如有错误发生时会发射"error"事件,有数据可被读取时发射"data"事件.这样我们就可以注册监听器来处理某个事件,达到我们的目的. Node.js定义了R