node中stream与buffer的关系

JavaScript 语言自身只有字符串数据类型,没有二进制数据类型。

但在处理像TCP流或文件流时,必须使用到二进制数据。因此在 Node.js中,定义了一个 Buffer 类,该类用来创建一个专门存放二进制数据的缓存区。

所以在一个应用程序中,stream是一组有序的、有起点和终点的字节数据的传输手段。

Buffer 用于创建一个专门存放二进制数据的缓存区

 

Stream 有四种流类型,且所有的 Stream 对象都是 EventEmitter 的实例: 
- Readable – 可读操作。 
- Writable – 可写操作。 
- Duplex – 可读可写操作. 
- Transform – 操作被写入数据,然后读出结果

 

在应用中,因为在后端与前端、后端的IO中,每当需要在 Node.js 中处理I/O操作中移动的数据时,就有可能使用 Buffer 库,很多时候会出现数据过大,不能一次性读取的问题。会导致程序的等待时间过长,因此,流操作(stream)便营运而生。

在readable和writable的Stream之间筑起沟通,如果仅仅使用事件方法来进行的话,代码会显得很冗杂,因此需要出现pipe(管道)方法来进行。

readable.pipe(writable);

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值