nodejs中的管道流和链式流
来源:互联网 发布:网络语言膜法什么意思 编辑:程序博客网 时间:2024/06/14 18:16
Stream 是一个抽象接口,Node 中有很多对象实现了这个接口。例如,对http 服务器发起请求的request 对象就是一个 Stream,还有stdout(标准输出)。
Node.js,Stream 有四种流类型:
Readable - 可读操作。
Writable - 可写操作。
Duplex - 可读可写操作.
Transform - 操作被写入数据,然后读出结果。
所有的 Stream 对象都是 EventEmitter 的实例。常用的事件有: data - 当有数据可读时触发。
end - 没有更多的数据可读时触发。
error - 在接收和写入过程中发生错误时触发。
finish - 所有数据已被写入到底层系统时触发。
如下面所示:
*读取数据流
创建 input.txt 文件,内容如下: this is a txt file
创建 main.js 文件, 代码如下:
var fs = require("fs");var data = '';// 创建可读流var readerStream = fs.createReadStream('input.txt');// 设置编码为 utf8。readerStream.setEncoding('UTF8');// 处理流事件 --> data, end, and errorreaderStream.on('data', function(chunk) { data += chunk;});readerStream.on('end',function(){ console.log(data);});readerStream.on('error', function(err){ console.log(err.stack);});console.log("程序执行完毕");
*写入流
创建 main.js 文件, 代码如下:
var fs = require("fs");var data = 'test dfddgfdgfdgfdgfd jkwu3';var writeStream = fs.createWriteStream('output.txt');writeStream.write(data,'UTF8');// 标记文件末尾writeStream.end();// 处理流事件 --> data, end, and errorwriteStream.on('finish', function() { console.log("写入完成。");});writeStream.on('error', function(err){ console.log(err.stack);});console.log("程序执行完毕");
*管道流
管道提供了一个输出流到输入流的机制。通常我们用于从一个流中获取数据并将数据传递到另外一个流中。我们把文件比作装水的桶,而水就是文件里的内容,我们用一根管子(pipe)连接两个桶使得水从一个桶流入另一个桶,这样就慢慢的实现了大文件的复制过程。
读写操作如下面代码所示:
var fs = require("fs");// 创建一个可读流var readerStream = fs.createReadStream('input.txt');// 创建一个可写流var writerStream = fs.createWriteStream('output.txt');// 管道读写操作// 读取 input.txt 文件内容,并将内容写入到 output.txt 文件中readerStream.pipe(writerStream);console.log("程序执行完毕");
如上面代码所示,当我们从input.txt文件中读取到数据时,我们就能够实时的通过pipe将数据写入到写入流,并进行保存到output.txt文件中.
*链式流
链式是通过连接输出流到另外一个流并创建多个对个流操作链的机制。链式流一般用于管道操作。
接下来我们就是用管道和链式来压缩和解压文件。
创建 compress.js 文件, 代码如下:
var fs = require("fs");var zlib = require('zlib');var data = 'test dfddgfdgfdgfdgfd jkwu';// 压缩 input.txt 文件为 input.txt.gzfs.createReadStream('input.txt') .pipe(zlib.createGzip()) .pipe(fs.createWriteStream('input.txt.gz'));console.log("程序执行完毕");
如上面代码,我们能够通过读取同等级目录下的input.txt文件,然后将其转化为input.txt.gz压缩文件
接下来,让我们来解压该文件,创建 decompress.js 文件,代码如下:
var fs = require("fs");var zlib = require('zlib');// 解压 input.txt.gz 文件为 input.txtfs.createReadStream('input.txt.gz') .pipe(zlib.createGunzip()) .pipe(fs.createWriteStream('input.txt'));console.log("文件解压完成。");
执行完程序之后,我们就能够得到input.txt文件,是上一步压缩的文件.
- 推荐阅读:nodejs中流(stream)的理解
- 菜鸟教程
- nodejs中的管道流和链式流
- 【重拾】nodeJS 管道流
- java中的管道流PiedOutputStream和PipeInputStream
- Java中的管道流
- Java中的管道流
- JAVA中的管道流
- Nodejs中的流
- nodejs中的流
- nodejs借用管道实现流数据边取边处理
- linux中的管道实现和管道
- linux中的匿名管道和命名管道
- 管道流PipedInputStream 和PipedOutputStream
- PipedInputStream和PipedOutputStream管道流
- 流、管道和重定向
- 流、管道和重定向
- PipedInputStream管道输出流和PipedOutputStream管道输入流
- JAVA中的管道流的简单用法
- java基础之IO流中的PipedStream管道流和RandomAcessFile
- 【ML笔记】LR和SVM的异同
- hjr教程-JavaScript(四):jquery插件开发
- SSH面试题整理
- 分布式系统调用链监控
- CodeIgniter框架源码学习之系统常量定义文件--constants.php
- nodejs中的管道流和链式流
- opencv3.0.0 读写视频
- JavaScript中的undefined与null
- codeforces 813C The Tag Game dfs
- A分类和预测算法的评估
- AsyncTask获取网络数据
- JSONObject、JSONArray
- Git分支管理的策略梳理
- 教大家如何区分屏蔽数据线的好坏