位置: 编程技术 - 正文

浅析Node.js 中 Stream API 的使用(nodejs stdin)

编辑:rootadmin

推荐整理分享浅析Node.js 中 Stream API 的使用(nodejs stdin),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs tostring,nodejs-lts,nodejs tostring,nodejs+ts,nodejs setinterval,nodejs setimmediate,nodejs stdin,nodejs stdout,内容如对您有帮助,希望把文章链接给更多的朋友!

本文由浅入深给大家介绍node.js stream api,具体详情请看下文吧。

基本介绍

在 Node.js 中,读取文件的方式有两种,一种是用 fs.readFile ,另外一种是利用 fs.createReadStream 来读取。

fs.readFile 对于每个 Node.js 使用者来说最熟悉不过了,简单易懂,很好上手。但它的缺点是会先将数据全部读入内存,一旦遇到大文件的时候,这种方式读取的效率就非常低下了。

而 fs.createReadStream 则是通过 Stream 来读取数据,它会把文件(数据)分割成小块,然后触发一些特定的事件,我们可以监听这些事件,编写特定的处理函数。这种方式相对上面来说,并不好上手,但它效率非常高。

事实上, Stream 在 Node.js 中并非仅仅用在文件处理上,其他地方也可以看到它的身影,如 process.stdin/stdout , http , tcp sockets , zlib , crypto 等都有用到。

本文是我学习 Node.js 中的 Stream API 中的一点总结,希望对大家有用。

特点

基于事件通讯

可以通过 pipe 来连接流

种类

Readable Stream 可读数据流

Writeable Stream 可写数据流

Duplex Stream 双向数据流,可以同时读和写

Transform Stream 转换数据流,可读可写,同时可以转换(处理)数据

事件

可读数据流的事件

readable 数据向外流时触发

data 对于那些没有显式暂停的数据流,添加data事件监听函数,会将数据流切换到流动态,尽快向外提供数据

end 读取完数据时触发。注意不能和 writeableStream.end() 混淆,writeableStream 并没有 end 事件,只有 .end() 方法

close 数据源关闭时触发

error 读取数据发生错误时触发

可写数据流的事件

drain writable.write(chunk) 返回 false 之后,缓存全部写入完成,可以重新写入时就会触发

finish 调用 .end 方法时,所有缓存的数据释放后触发,类似于可读数据流中的 end 事件,表示写入过程结束

pipe 作为 pipe 目标时触发

浅析Node.js 中 Stream API 的使用(nodejs stdin)

unpipe 作为 unpipe 目标时触发

error 写入数据发生错误时触发

状态

可读数据流有两种状态: 流动态 和 暂停态 ,改变数据流状态的方法如下:

暂停态 -> 流动态

添加 data 事件的监听函数

调用 resume 方法

调用 pipe 方法

注意:如果转为流动态时,没有 data 事件的监听函数,也没有 pipe 方法的目的地,那么数据将遗失。

流动态 -> 暂停态

不存在 pipe 方法的目的地时,调用 pause 方法

存在 pipe 方法的目的地时,移除所有 data 事件的监听函数,并且调用 unpipe 方法,移除所有 pipe 方法的目的地

注意:只移除 data 事件的监听函数,并不会自动引发数据流进入「暂停态」。另外,存在 pipe 方法的目的地时,调用 pause 方法,并不能保证数据流总是处于暂停态,一旦那些目的地发出数据请求,数据流有可能会继续提供数据。

用法

读写文件

更多用法

可以参考一下 ,进去示例网站之后直接点 add stream 就能看到结果了。

常见坑

用 rs.pipe(ws) 的方式来写文件并不是把 rs 的内容 append 到 ws 后面,而是直接用 rs 的内容覆盖 ws 原有的内容

已结束/关闭的流不能重复使用,必须重新创建数据流

pipe 方法返回的是目标数据流,如 a.pipe(b) 返回的是 b,因此监听事件的时候请注意你监听的对象是否正确

如果你要监听多个数据流,同时你又使用了 pipe 方法来串联数据流的话,你就要写成:

data

常用类库

event-stream 用起来有函数式编程的感觉,个人比较喜欢

awesome-nodejs#streams 由于其他 stream 库我都没用过,所以有需求的就直接看这里吧

以上内容是小编给大家介绍的Node.js 中 Stream API 的使用,希望大家喜欢。

Nodejs实战心得之eventproxy模块控制并发 目标建立一个lesson4项目,在其中编写代码。代码的入口是app.js,当调用nodeapp.js时,它会输出CNode(

node.js回调函数之阻塞调用与非阻塞调用 首先,node.js作为javascript运行平台,它采用了事件驱动和异步编程的方式,通过事件注册和异步函数,开发人员可以提高资源利用率,服务器的性能也能

node.js抓取并分析网页内容有无特殊内容的js文件 nodejs获取网页内容绑定data事件,获取到的数据会分几次相应,如果想全局内容匹配,需要等待请求结束,在end结束事件里把累积起来的全局数据进行操

标签: nodejs stdin

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

上一篇:浅谈node.js中async异步编程(node.js axios)

下一篇:Nodejs实战心得之eventproxy模块控制并发(node.js 10实战)

  • 个人所得税的账务处理
  • 个人所得税起征点2023税率表
  • 什么是增值税征免年限
  • 纳税人对所提交信息的什么负责
  • 公司账户短期理财收益要交税吗
  • 无发票的费用怎样补交所得税
  • 个体户可以不开公户吗?打款到法人卡
  • 做账一定要银行对账单吗
  • 没发票的费用怎么做账
  • 拆迁补偿费返还政策
  • 抵扣联的抵扣期限
  • 个人代人开普票个税怎么算
  • 领用低值易耗品的记账凭证
  • 基金会计核算的核算主体是
  • 预付账款转出分录
  • 个人股东无偿借款给企业
  • 地址变更工商局上门检查
  • 进项税使报表应交税费负数如何处理?
  • 施工服务费税率9%
  • 关于金融行业的经典句子
  • 生活服务的发票可以报销吗
  • 外商投资企业外债额度
  • 出售股票公允价值变动损益
  • 怎么处理有问题的货物
  • 土地租赁摊销年限按合同年限
  • 跨月的红字发票
  • 质押已至票据到期日
  • 长期待摊费用2021
  • 筹建期间的租赁费计入
  • 发票冲红怎么开具
  • php处理的图片格式是什么
  • 小微企业免征税额度
  • windows的记事本的扩展名
  • 错误申报多交增值税已经扣税
  • 布鲁克斯的故事
  • 帝国cms移动端
  • 借款是经营性负债吗
  • 文化事业2021
  • 开出增值税发票一定要确认收入吗?
  • command对象可以执行sql语句吗
  • web网页设计期末作业猫眼电影首页
  • 商品交换包括
  • 购入库存商品会计分录摘要
  • 中标违约保证金怎么算
  • 现金流量表本月数和本年累计数是相等的么
  • 帝国cms8.0
  • 金蝶k3明细账如何查询
  • 两者有什么区别用英语怎么说
  • 建筑公司算不算企业
  • 手机开个人劳务票怎么开
  • 银行承兑汇票提示付款期为几天
  • 如何调整去年的账
  • 存货价值的计算公式
  • 小额贷款在银行需要什么条件
  • 勾选认证能够勾选当月
  • 只有进项税额没有销项税额怎么结转
  • 小微企业记账必须有会计证吗
  • 刻章费发票怎么开
  • 房地产开发企业资质管理规定
  • 商业企业费用的计算方法
  • sqlserver存储过程声明变量
  • 操作系统中的三级调度
  • windows8休眠如何唤醒
  • xp安全模式怎么用
  • ubuntu16.04命令行配置静态ip
  • Ubuntu操作系统安装步骤
  • 安装WIN10系统后怎么调过设置
  • 四步制作的花
  • jquery炫酷效果
  • shell脚本实现同时多台远程主机执行命令的代码分享
  • python科学绘图
  • pip工具安装
  • javascript语法术语
  • vue怎么实现多页面
  • cument.execCommand()用法深入理解
  • Android studio第一行报错
  • android开发app
  • 套接字java
  • 广东国家税务局电子税务局官网入口
  • 为什么要进行进气歧管真空度检测
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设