视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
node.js利用流实现读写同步,边读边写的功能
2020-11-27 19:34:45 责编:小OO
文档


下面为大家带来一篇node.js 利用流实现读写同步,边读边写的方法。内容挺不错的,现在就分享给大家,也给大家做个参考。

如下所示:

//10个数 10个字节,每次读4b,写1b
let fs=require("fs");
function pipe(source,target) {
 //先创建可读流,再创建可写流
 //先读一次,rs.on(data)
 //将读到的类容写入目标中 ,返回布尔值,如果是ture,继续写,默认情况应该是false,暂停读取
 //ws.on('drain'),抽干后,回复读取
 //监听读取文件完毕后,关闭读取rs.on('end')

 let rs=fs.createReadStream(source,{highWaterMark:4});
 let ws=fs.createWriteStream(target,{highWaterMark:1});

 rs.on('data',function (chunk) { //chunk是buffer类型

 if(ws.write(chunk)===false){
 //写不下,停止读取
 rs.pause()
 }

 });
 ws.on('drain',function () {
 //每次写的内存干了就恢复读取
 console.log("111");
 rs.resume() //恢复读取
 });
 rs.on('end',function (chunk) {
 ws.end();
 })

}
pipe('./1.txt','./3.txt')

上面这种写法比较繁琐,大家看完后,忘记就行

node.js提供给我们内置方法pipe

//10个数 10个字节,每次读4b,写1b
let fs=require("fs");
function pipe(source,target) {

 let rs=fs.createReadStream(source,{highWaterMark:4});
 let ws=fs.createWriteStream(target,{highWaterMark:1});
 //可读流到可写流,异步操作,可以保证内存不会被淹没,读一点,写一点
 // 如果想看文件类容,使用readFile

 rs.pipe(ws);
}
pipe('./1.txt','./4.txt')

直接将读取的流操作到写入流中,还是异步操作

下载本文
显示全文
专题