位置: 编程技术 - 正文

Node.js中的流(Stream)介绍(node.js 流)

编辑:rootadmin

推荐整理分享Node.js中的流(Stream)介绍(node.js 流),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs文件流,node.js的流的作用,nodejs文件流,node.js的流的主要作用,node.js的流的作用,nodejs的流处理模块,nodejs的流处理模块,node.js的流的作用,内容如对您有帮助,希望把文章链接给更多的朋友!

什么是流?

说到流,就涉及到一个*nix的概念:管道——在*nix中,流在Shell中被实现为可以通过 |(管道符) 进行桥接的数据,一个进程的输出(stdout)可被直接作为下一个进程的输入(stdin)。

在Node中,流(Stream)的概念与之类似,代表一种数据流可供桥接的能力。

pipe

流化的精髓在于 .pipe()方法。可供桥接的能力,在于数据流的两端(上游/下游 或称为 读/写流)以一个 .pipe()方法进行桥接。

伪代码的表现形式为:

流的分类

这里并不打算讨论所谓的Node v0.4 之前的“经典”流。那么,流分为这么几类(皆为抽象接口:

1.stream.Readable 可读流(需要实现_read方法,关注点在于对数据流读取的细节2.stream.Writable 可写流(需要实现_write方法,关注点在于对数据流写入的细节3.stream.Duplex 可读/写流(需要实现以上两接口,关注点为以上两接口的细节4.stream.Transform 继承自Duplex(需要实现_transform方法,关注点在于对数据块的处理

简单来说:

1).pipe() 的拥有者一定具备 Readable 流(并不局限于)能力,它拥有 'readable'/'data'/'end'/'close'/'error' 一系列事件可供订阅,也提供 .read()/.pause()/.resume()等一系列方法供调用;2).pipe() 的参数一定具备Writable 流(并不局限于 )能力,它拥有 'drain'/'pipe'/'unpipe'/'error'/'finish' 事件可供访问,也提供 .write()/.end() 等一系列方法供调用

什么鬼

有没有一丝丝焦虑?别急,做为一个说人话的低级码工,我会把Stream掰开了和您扯一扯的。

Stream类,在 Node.js的源码 里,是这么定义的:

Node.js中的流(Stream)介绍(node.js 流)

可以看出,本质上,Stream是一个EventEmitter,那意味着它具备事件驱动的功能(.emit/.on...)。众所周知,“Node.js 就是基于V8的事件驱动平台”,实现了事件驱动的流式编程,具备了和Node一样的异步回调的特征。

比如在 Readable 流中,有一个 readable 事件,在一个暂停的只读流中,只要有数据块准备好可读时,它就会被发送给订阅者(Readable 流有哪些呢?express中的 req,ftp或者mutli-form上传组件的req.part,系统中的标准输入 process.stdin等)。有了readable 事件,我们可以做个处理shell 命令输出的分析器之类的工具:

这样调用:

对于 Readable 流,我们还可以订阅它的 data 和 end 事件,以获取数据块并在流枯竭时获得通知,如 经典socket示例 中那样:

Readable流状态的切换需要注意的是,Readable 流有两种状态:flowing mode(激流) 和 pause mode(暂停)。前者根本停不下来,谁被pipe上了就马上不停的给;后者会暂停,直到下游显式的调用 Stream.read() 请求才读取数据块。Readable 流初始化时是 pause mode的。

这两种状态可以互为切换的,其中,

有以下任一行为,pause 转 flowing:

1.对 Readable 流添加一个data事件订阅2.对 Readable 调用 .resume() 显式开启flowing3.调用 Readable 流的 .pipe(writable) ,桥接到一个 Writable 流上

有以下任一行为,flowing 转回 pause:

1.Readable 流还没有 pipe 到任何流上,可调 .pause() 暂停2.Readable 流已经 pipe 到了流上,需 remove 掉所有 data 事件订阅,并且调用 .unpipe()方法逐一解除与下游流的关系

妙用

结合流的异步特性,我可以写出这样的应用:直接将 用户A 的输出桥接到 用户B 的页面上输出:

用户B请求的时候:

参考

how to write node programs with streams: stream-handbook

Node.js 异步编程之 Callback介绍(一) Node.js基于JavaScript引擎v8,是单线程的。Node.js采用了与通常Web上的JavaScript异步编程的方式来处理会造成阻塞的I/O操作。在Node.js中读取文件、访问数据库

初识Node.js 先来简单介绍nodeJS我们知道JavaScript是运行在浏览器中的,浏览器为它提供了一个上下文(context),从而让JavaScript得以解析执行。nodeJS其实可以这么理解,

nodejs中实现sleep功能实例 nodejs最让人不爽的就是其单线程特性,很多事情没法做,对CPU密集型的场景,性能也不够强劲。很长一段时间,我想在javascript语言框架下寻求一些解决

标签: node.js 流

本文链接地址:https://www.jiuchutong.com/biancheng/378014.html 转载请保留说明!

上一篇:ubuntu下安装nodejs以及升级的办法(ubuntu下安装visual studio)

下一篇:Node.js 异步编程之 Callback介绍(一)(nodejs 异步任务队列)

  • 车辆保险的车船税怎么算
  • 电子承兑汇票怎么做账
  • 贷款公司股权转让合法吗
  • 环保税退税优惠政策
  • 境外企业在境内取得的收入所得税
  • 给客户现金回款怎么写
  • 单位的收入是刷卡怎么做账
  • 餐饮增值税发票税率
  • 税法关于印花税的规定
  • 可以自行设计的软件
  • 利润减库存为什么不等于现金
  • 注册会计师考点分析
  • 一般纳税人出售不动产增值税税率是多少
  • 房子报废
  • 资产总额从业人数
  • 交通运输服务增值税税率
  • 融资租入固定资产计提折旧吗
  • 仓库收料作业指导书
  • bios设置启动顺序(图解说明)
  • mac u盘
  • Qq浏览器里的文档怎么以文件形式发送
  • 琼斯的大海怪
  • searchnav.exe - searchnav是什么进程 有什么用
  • 公司注销职工安置方案
  • ros source
  • 智能路由器五个灯一直闪
  • 银行支付的存款怎么做账
  • 秋分日的时间意义庆祝方式
  • 马耳他共和国瓦莱塔福利
  • 龙舌兰 (© Moab Republic/Shutterstock)
  • 成品油发票当月冲红
  • php手机号隐藏中间四位
  • 税控盘的发票怎么做账
  • 前端手撕代码
  • 如何在idea上运行python
  • 11个点的是什么星座
  • 核定征收的方式包括
  • 计算机网络面试八股文
  • 计提税费可以记入成本吗
  • mysql5.5命令
  • mongodb基础知识
  • 担保公司代偿会上征信嘛
  • 备案办税人员信息是谁
  • 什么是指企业的市场营销活动发生影响的各种因素的总和
  • 在非企业合并形成的长期股权投资中
  • 分公司是否具有独立承担民事责任的能力
  • 高速过路费发票图片
  • 分配股利有几种形式
  • 在建工程发生的运费计入什么科目
  • 无发票材料可以入材料账吗
  • 专利补贴收入计入什么科目
  • 水利基金减免
  • 主营业务成本可以设明细科目吗
  • 存货账面价值的确定
  • 承租人对融资租赁业务进行会计处理的方法有( )
  • 电子发票一定要盖章吗
  • mac开机后蓝屏没反应
  • 破解ssh端口
  • 如何进入opencore引导
  • os x 10.11 el capitan中文版上手体验评测
  • win7计算机怎么设置开机密码
  • win7如何更改欢迎界面
  • win7系统电脑蓝牙怎么开
  • Win10系统中怎么将文件夹进行压缩
  • 电脑系统脚本错误
  • 函数里面声明函数
  • win7怎么设定关机时间
  • js nextSibling属性和previousSibling属性概述及使用注意
  • cocos2dx-3.2+lua 常用代码
  • angularjs4
  • javascript 变量
  • nodejs基础
  • nodeJS(express4.x)+vue(vue-cli)构建前后端分离实例(带跨域)
  • python二叉树
  • js做时钟让钟表转起来
  • unity基于什么语言
  • twist python
  • 国家税务局通用机打发票查询
  • 国家税务总局12366纳税服务平台
  • 普惠性税收优惠政策例子
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设