nodejs-Sream
2016-03-20 15:40
761 查看
Stream 是一个抽象接口,Node 中有很多对象实现了这个接口。例如,对http 服务器发起请求的request 对象就是一个 Stream,还有stdout(标准输出)。
Node.js,Stream 有四种流类型:
Readable - 可读操作。
Writable - 可写操作。
Duplex - 可读可写操作.
Transform - 操作被写入数据,然后读出结果。
所有的 Stream 对象都是 EventEmitter 的实例。常用的事件有:
data - 当有数据可读时触发。
end - 没有更多的数据可读时触发。
error - 在接收和写入过程中发生错误时触发。
finish - 所有数据已被写入到底层系统时触发。
[/code]
来自为知笔记(Wiz)
Node.js,Stream 有四种流类型:
Readable - 可读操作。
Writable - 可写操作。
Duplex - 可读可写操作.
Transform - 操作被写入数据,然后读出结果。
所有的 Stream 对象都是 EventEmitter 的实例。常用的事件有:
data - 当有数据可读时触发。
end - 没有更多的数据可读时触发。
error - 在接收和写入过程中发生错误时触发。
finish - 所有数据已被写入到底层系统时触发。
var fs = require("fs");
var data = '';
// 创建可读流
var readerStream = fs.createReadStream('input.txt');
// 设置编码为 utf8。
readerStream.setEncoding('UTF8');
// 处理流事件 --> data, end, and error
// 有数据返回的时候,后台会出发eventEmitter.emit('data')事件
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("程序执行完毕");
[/code]
管道流
链式流
相关文章推荐
- nodejs-Buffer
- nodejs-EventEmitter
- nodejs-fs模块
- nodejs-基本语法
- nodejs-NPM基本使用
- Node.js-入门
- nodejs-配置vs code的插件
- ubuntu14.04下安装ngnix,mediawiki,nodebb,everything,gitlab
- Node.js处理I/O数据之Buffer模块缓冲数据
- Hadoop NameNode元数据相关文件目录解析
- Node.js中的全局对象global(一)
- leetcode 25. Reverse Nodes in k-Group
- nodejs学习-socket.io
- Node.js链式回调
- node源码详解(五) —— 在main函数之前 —— js和C++的边界,process.binding
- 19. Remove Nth Node From End of List
- nodejs learn
- node源码详解(四) —— js代码如何调用C++的函数
- 基于angular的route实现单页面cnodejs
- nodepad++搭建各种开发环境