为什么要需要流?
- 当我们学习新知识的时候,首先我们知道为什么要学习,那我们为什么要学习流?因为在在node中读取文件的方式有来两种,一个是利用fs模块,一个是利用流来读取。如果读取小文件,我们可以使用fs读取,fs读取文件的时候,是将文件一次性读取到本地内存。而如果读取一个大文件,一次性读取会占用大量内存,效率很低,这个时候需要用流来读取。流是将数据分割段,一段一段的读取,可以控制速率,效率很高,不会占用太大的内存。gulp的task任务,文件压缩,和http中的请求和响应等功能的实现都是基于流来实现的。因此,系统学习下流还是很有必要的
可读流用法(先把用法学会)
- node中读是将内容读取到内存中,而内存就是Buffer对象
- 流都是基于原生的fs操作文件的方法来实现的,通过fs创建流。所有的 Stream 对象都是 EventEmitter 的实例。常用的事件有:
- open -打开文件
- data -当有数据可读时触发。
- error -在读收和写入过程中发生错误时触发。
- close -关闭文件
- end - 没有更多的数据可读时触发
创建可读流
- 统一下 1.txt中的内容 1234567890
let fs = require('fs');
let rs = fs.createReadStream('./1.txt',{
highWaterMark:3, //文件一次读多少字节,默认 64*1024
flags:'r', //默认 'r'
autoClose:true, //默认读取完毕后自动关闭
start:0, //读取文件开始位置
end:3, //流是闭合区间 包含start也含end
encoding:'utf8' //默认null
});
复制代码
- 注意: 默认创建一个流 是非流动模式,默认不会读取数据
- 具体参数说明,我们可以参考下node官网详细介绍
监听open事件
rs.on("open",()=>{
console.log("文件打开")
});
复制代码
监听data事件
-
可读流这种模式它默认情况下是非流动模式(暂停模式),它什么也不做,就在这等着
-
监听了data事件的话,就可以将非流动模式转换为流动模式
-
流动模式会疯狂的触发data事件,直到读取完毕
-
直接上代码
//1.txt中内容为1234567890
let fs = require('fs');