Node的数据流、事件处理

本文详细介绍了Node.js中的数据流和事件处理。数据流分为四种类型:Readable、Writable、Duplex和Transform,提供了高效处理大文件和数据流的方式。事件处理则采用事件驱动模型,使用EventEmitter类绑定和监听事件。此外,还展示了如何通过Node的readline模块实现终端的输入。
摘要由CSDN通过智能技术生成

目录

一、Node的数据流(Stream)

二、Node的事件处理

三、通过Node的readline模块实现终端的输入


一、Node的数据流(Stream)

数据读写可以看作是事件模式(Event)的特例,不断发送的数据块好比一个个的事件。读数据是read事件,写数据是write事件,而数据块是事件附带的信息。Node 为这类情况提供了一个特殊接口Stream

1、处理缓存的方式

数据流(stream)是处理系统缓存的一种方式。操作系统采用数据块(chunk)的方式读取数据,每收到一次数据,就存入缓存。Node应用程序有两种缓存的处理方式:

(1)一次性全部读取,然后再进行处理。缺点是大文件处理非常耗时,优点是过程直观

(2)读取一块处理一块。优点是提高程序的性能

2、四种类型的流

流是可以从一个源读取或写入数据到连续的目标对象。在Node.js,有四种类型的数据流。

  • Readable - 其是用于读操作。
  • Writable - 用在写操作。
  • Duplex - 其可以用于读取和写入操作。
  • Transform - 输出基于输入的地方进行计算的一种双相流。

每种类型的流是一个EventEmitter实例,并抛出的不同的事件。 

例如,一些常用的事件是:

  • data - 当有数据可读取此事件。
  • end - 当没有更多的数据读取此事件被触发。
  • error - 当有任何错误或接收数据写入此事件。
  • finish - 当所有数据已刷新到底层系统触发此事件

1、从流中读取fs模块的createReadStream方法,就可以创建一个读取数据的数据流。

 2、写入流:fs模块的createWriteStream方法,就可以创建一个数据的数据流。

const fs = require('fs')

let str_data = '';

//创建读数据的流
let readerStream = fs.createReadStream('./input.txt')

//设置流的编码格式
readerStream.setEncoding('utf8')

//给流绑定事件
readerStream.on('data',function (chunk){
    str_data += chunk
})

readerStream.on('end',function (){
    console.log('读取的数据是:',str_data)
})

readerStream.on('error',function (err){
    console.log(err.stack)
})
console.log('---------end----------')

 

3、管道流:管道是供一个流的输出作为输入到另一个流的机制。它通常被用于从一个流中获取数据,并通过该流输出到另一个流。

 例如:一个管道从一个文件中读取和写入到另一个文件

const fs = require('fs')

//创建一个读数据的流
let readerStream = fs.createReadStream('./test.txt')

//创建一个写数据的流
let writeStream = fs.createWriteStream('./input.txt')

//创建管道流
readerStream.pipe(writeStream)
console.log('-----end----')

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陛下,再来一杯娃哈哈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值