码迷,mamicode.com
首页 > Web开发 > 详细

nodejs-Sream

时间:2016-03-20 16:12:50      阅读:233      评论:0      收藏:0      [点我收藏+]

标签:

Stream 是一个抽象接口,Node 中有很多对象实现了这个接口。例如,对http 服务器发起请求的request 对象就是一个 Stream,还有stdout(标准输出)。

Node.js,Stream 有四种流类型:

  • Readable - 可读操作。

  • Writable - 可写操作。

  • Duplex - 可读可写操作.

  • Transform - 操作被写入数据,然后读出结果。

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

  • data - 当有数据可读时触发。

  • end - 没有更多的数据可读时触发。

  • error - 在接收和写入过程中发生错误时触发。

  • finish - 所有数据已被写入到底层系统时触发。


    1. var fs = require("fs");
    2. var data = ‘‘;
    3. // 创建可读流
    4. var readerStream = fs.createReadStream(‘input.txt‘);
    5. // 设置编码为 utf8。
    6. readerStream.setEncoding(‘UTF8‘);
    7. // 处理流事件 --> data, end, and error
    8. // 有数据返回的时候,后台会出发eventEmitter.emit(‘data‘)事件
    9. readerStream.on(‘data‘, function(chunk) {
    10. data += chunk;
    11. });
    12. readerStream.on(‘end‘,function(){
    13. console.log(data);
    14. });
    15. readerStream.on(‘error‘, function(err){
    16. console.log(err.stack);
    17. });
    18. console.log("程序执行完毕");

管道流

1
2
3
4
5
6
7
8
9
10
11
12
13
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("程序执行完毕");

链式流

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
// --------------链式流-----------
// -------------压缩文件-----------
var fs = require("fs");
var zlib = require(‘zlib‘);
 
// 压缩 input.txt 文件为 input.txt.gz
fs.createReadStream(‘input.txt‘)
  .pipe(zlib.createGzip())
  .pipe(fs.createWriteStream(‘input.txt.gz‘));
   
console.log("文件压缩完成。");
// ----------------解压文件-------
var fs = require("fs");
var zlib = require(‘zlib‘);
 
// 解压 input.txt.gz 文件为 input.txt
fs.createReadStream(‘input.txt.gz‘)
  .pipe(zlib.createGunzip())
  .pipe(fs.createWriteStream(‘input.txt‘));
   
console.log("文件解压完成。");









nodejs-Sream

标签:

原文地址:http://www.cnblogs.com/weloveshare/p/5297936.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!