node.js 利用流实现读写同步,边读边写的方法


Posted in Javascript onSeptember 11, 2017

如下所示:

//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')

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

以上这篇node.js 利用流实现读写同步,边读边写的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 对象、函数和继承
Jul 07 Javascript
window.location.hash 属性使用说明
Mar 20 Javascript
jQuery 验证插件 Web前端设计模式(asp.net)
Oct 17 Javascript
jquery自定义滚动条插件示例分享
Feb 21 Javascript
jQuery实现左右切换焦点图
Apr 03 Javascript
PHP+jQuery+Ajax+Mysql如何实现发表心情功能
Aug 06 Javascript
JS实现动态生成表格并提交表格数据向后端
Nov 25 Javascript
Function.prototype.apply()与Function.prototype.call()小结
Apr 27 Javascript
微信小程序 Template详解及简单实例
Jan 05 Javascript
js+html制作简单验证码
Feb 16 Javascript
vue.js异步上传文件前后端实现代码
Aug 22 Javascript
vue图片加载失败时用默认图片替换的方法
Aug 29 Javascript
checkbox:click事件触发span元素内容改变的方法
Sep 11 #Javascript
Node.js 使用流实现读写同步边读边写功能
Sep 11 #Javascript
node.js 核心http模块,起一个服务器,返回一个页面的实例
Sep 11 #Javascript
简单谈谈JS中的正则表达式
Sep 11 #Javascript
详解Vue双向数据绑定原理解析
Sep 11 #Javascript
基于DOM节点删除之empty和remove的区别(详解)
Sep 11 #Javascript
在原生不支持的旧环境中添加兼容的Object.keys实现方法
Sep 11 #Javascript
You might like
网站当前的在线人数
2006/10/09 PHP
PHP 第二节 数据类型之数值型
2012/04/28 PHP
php中chdir()函数用法实例
2014/11/13 PHP
JavaScript Array扩展实现代码
2009/10/14 Javascript
javascript 进阶篇2 CSS XML学习
2012/03/14 Javascript
jQuery 插件开发指南
2014/11/14 Javascript
jQuery大于号(>)选择器的作用解释
2015/01/13 Javascript
js实现人才网站职位选择功能的方法
2015/08/14 Javascript
javascript每日必学之继承
2016/02/23 Javascript
浅谈javascript中new操作符的原理
2016/06/07 Javascript
jQuery Tags Input Plugin(添加/删除标签插件)详解
2016/06/20 Javascript
JS原型链怎么理解
2016/06/27 Javascript
ES6数组的扩展详解
2017/04/25 Javascript
详解如何使用webpack在vue项目中写jsx语法
2017/11/08 Javascript
vue项目中用cdn优化的方法
2018/01/03 Javascript
js实现烟花特效
2020/03/02 Javascript
JS数组reduce()方法原理及使用技巧解析
2020/07/14 Javascript
vue-resource 拦截器interceptors使用详解
2021/01/18 Vue.js
[36:29]2018DOTA2亚洲邀请赛 4.1 小组赛 A组加赛 LGD vs TNC
2018/04/02 DOTA
python基础教程之python消息摘要算法使用示例
2014/02/10 Python
Python制作爬虫采集小说
2015/10/25 Python
python学习教程之Numpy和Pandas的使用
2017/09/11 Python
获取python文件扩展名和文件名方法
2018/02/02 Python
Python的bit_length函数来二进制的位数方法
2019/08/27 Python
tensorflow获取预训练模型某层参数并赋值到当前网络指定层方式
2020/01/24 Python
Python json读写方式和字典相互转化
2020/04/18 Python
pandas将list数据拆分成行或列的实现
2020/12/13 Python
python上下文管理的使用场景实例讲解
2021/03/03 Python
AmazeUI中各种的导航式菜单与解决方法
2020/08/19 HTML / CSS
荟萃全球保健品:维他购
2018/05/09 全球购物
GWT的应用有哪两种部署模式
2012/12/21 面试题
2014年乡镇民政工作总结
2014/12/02 职场文书
采购员岗位职责
2015/02/03 职场文书
2015年消防工作总结
2015/04/24 职场文书
师德培训心得体会2016
2016/01/09 职场文书
python之json文件转xml文件案例讲解
2021/08/07 Python