最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

node.js利用流实现读写同步,边读边写的功能

来源:懂视网 责编:小OO 时间:2020-11-27 19:34:45
文档

node.js利用流实现读写同步,边读边写的功能

如下所示。,//10个数 10个字节,每次读4b,写1blet 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。
推荐度:
导读如下所示。,//10个数 10个字节,每次读4b,写1blet 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。

下面为大家带来一篇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')

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

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

node.js利用流实现读写同步,边读边写的功能

如下所示。,//10个数 10个字节,每次读4b,写1blet 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。
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top