目录
一、Node的数据流(Stream)
数据读写可以看作是事件模式(Event)的特例,不断发送的数据块好比一个个的事件。读数据是read事件,写数据是write事件,而数据块是事件附带的信息。Node 为这类情况提供了一个特殊接口Stream。
1、处理缓存的方式
“数据流”(stream)是处理系统缓存的一种方式。操作系统采用数据块(chunk)的方式读取数据,每收到一次数据,就存入缓存。Node应用程序有两种缓存的处理方式:
(1)一次性全部读取,然后再进行处理。缺点是大文件处理非常耗时,优点是过程直观
(2)读取一块处理一块。优点是提高程序的性能
2、四种类型的流
流是可以从一个源读取或写入数据到连续的目标对象。在Node.js,有四种类型的数据流。
- Readable - 其是用于读操作。
- Writable - 用在写操作。
- Duplex - 其可以用于读取和写入操作。
- Transform - 输出基于输入的地方进行计算的一种双相流。
每种类型的流是一个EventEmitter实例,并抛出的不同的事件。
例如,一些常用的事件是:
- data - 当有数据可读取此事件。
- end - 当没有更多的数据读取此事件被触发。
- error - 当有任何错误或接收数据写入此事件。
- finish - 当所有数据已刷新到底层系统触发此事件
1、从流中读取:fs模块的createReadStream方法,就可以创建一个读取数据的数据流。
2、写入流:fs模块的createWriteStream方法,就可以创建一个写数据的数据流。
const fs = require('fs')
let str_data = '';
//创建读数据的流
let readerStream = fs.createReadStream('./input.txt')
//设置流的编码格式
readerStream.setEncoding('utf8')
//给流绑定事件
readerStream.on('data',function (chunk){
str_data += chunk
})
readerStream.on('end',function (){
console.log('读取的数据是:',str_data)
})
readerStream.on('error',function (err){
console.log(err.stack)
})
console.log('---------end----------')
3、管道流:管道是供一个流的输出作为输入到另一个流的机制。它通常被用于从一个流中获取数据,并通过该流输出到另一个流。
例如:一个管道从一个文件中读取和写入到另一个文件
const fs = require('fs')
//创建一个读数据的流
let readerStream = fs.createReadStream('./test.txt')
//创建一个写数据的流
let writeStream = fs.createWriteStream('./input.txt')
//创建管道流
readerStream.pipe(writeStream)
console.log('-----end----')