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