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);

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章