nodeJS基础 Stream用法

633 阅读2分钟

Stream是nodeJS的一个核心模块,在nodeJS中应用非常广泛,比如HTTP 服务器request和response对象都是流

  • 流的特点 1.有序的 2.有方向的
  • 流分分为两种 1.可读流 2.可写流
  • 流不关心文件的整体内容,只关注是否从文件中读到了数据,以及读到数据之后的处理

可读流的用法

let fs = require('fs');
let path = require('path');
let rs = fs.createReadStream(path.join(__dirname, '1.txt'), {
    flags: 'r', // 文件的操作是读取操作
    encoding: 'utf8', // 默认是null null代表的是buffer
    autoClose: true, // 读取完毕后自动关闭
    highWaterMark: 3, // 默认是64k  64*1024b
    start: 0,
    end:3
});

默认情况下不会将文件中的内容输出
内部会先创建一个Buffer先读取3b(三字节)
如果你不进行操作,默认是非流动模式,暂停状态
当监听data事件后,开始发射数据

rs.on('data', function (data) {
    console.log(data);
    //读取

});

暂停方法 暂停data事件触发

rs.pause();

恢复方法 恢复data事件触发

rs.resume();

除了data事件,可读流还能监听其他一些事件

end事件(暂停)
该事件会在读完数据后被触发

rs.on('end', function () {
    console.log('读取完成');
});

error事件
如果有错误会会触发

rs.on('error', function (err) {
    console.log(err);
});

open事件
打开文件

rs.on('open', function () {
    console.log('文件打开');
});

close事件
关闭文件

rs.on('close', function () {
    console.log('文件关闭');
});

设置编码

rs.setEncoding('utf8');

可写流的用法

let fs = require('fs');
let ws = fs.createWriteStream('./4.txt', {
    flages: 'w',     //读写标识符
    mode: 0o666, // 权限
    autoClose: true, // 是否自动关闭
    highWaterMark: 3, // 默认是16k
    encoding: 'utf8', // 编码格式
    start: 0 //从哪开始
});

相对于可读流,可写流的方法就少多了

write方法
写入后会返回一个布尔值,来判断系统缓存区是否满了

let flag = ws.write('写入的内容','utf8',function(){});
console.log(flag);

end方法
关闭方法,再关闭前可以最后传入一次数据

ws.write('最后写入的内容','utf8',function(){});

drain方法
抽干方法 当写入完后,会触发 必须缓存区满了被清空后才会出发drain事件

ws.on('drain', function () {
    console.log('抽干')
})