node.js 利用流实现读写同步,边读边写的方法
如下所示:
//10个数10个字节,每次读4b,写1b
letfs=require("fs");
functionpipe(source,target){
//先创建可读流,再创建可写流
//先读一次,rs.on(data)
//将读到的类容写入目标中,返回布尔值,如果是ture,继续写,默认情况应该是false,暂停读取
//ws.on('drain'),抽干后,回复读取
//监听读取文件完毕后,关闭读取rs.on('end')
letrs=fs.createReadStream(source,{highWaterMark:4});
letws=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
letfs=require("fs");
functionpipe(source,target){
letrs=fs.createReadStream(source,{highWaterMark:4});
letws=fs.createWriteStream(target,{highWaterMark:1});
//可读流到可写流,异步操作,可以保证内存不会被淹没,读一点,写一点
//如果想看文件类容,使用readFile
rs.pipe(ws);
}
pipe('./1.txt','./4.txt')
直接将读取的流操作到写入流中,还是异步操作
以上这篇node.js利用流实现读写同步,边读边写的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。