面试官:说说你对 Node 中的 Stream 的理解
前言
面试官:“说说你对 Node 中的 Stream 的理解”
紧张的萌新:“好像是一种流?...”
面试官:“...”
······
大家好,我是 CoderBin。又来到了面试官系列,本次讲解的是 node 中关于 Stream 的相关知识,属于 node 知识的范围。希望对大家有所帮助,谢谢!如果文中有不对、疑惑的地方,欢迎在评论区留言指正🌻
高频面试总结
面试官系列文章
【1】面试官系列-专栏
一、是什么
流(Stream),是一个数据传输手段,是端到端信息交换的一种方式,而且是有顺序的,是逐块读取数据、处理内容,用于顺序读取输入或写入输出
Node.js
中很多对象都实现了流,总之它是会冒数据(以 Buffer
为单位)
它的独特之处在于,它不像传统的程序那样一次将一个文件读入内存,而是逐块读取数据、处理其内容,而不是将其全部保存在内存中
流可以分成三部分:source
、dest
、pipe
在source
和dest
之间有一个连接的管道pipe
,它的基本语法是source.pipe(dest)
,source
和dest
就是通过 pipe 连接,让数据从source
流向了dest
,如下图所示:
二、种类
在NodeJS
,几乎所有的地方都使用到了流的概念,分成四个种类:
可写流:可写入数据的流。例如
fs.createWriteStream()
可以使用流将数据写入文件可读流:可读取数据的流。例如
fs.createReadStream()
可以从文件读取内容双工流:既可读又可写的流。例如
net.Socket
转换流:可以在数据写入和读取时修改或转换数据的流。例如,在文件压缩操作中,可以向文件写入压缩数据,并从文件中读取解压数据
在NodeJS
中HTTP
服务器模块中,request
是可读流,response
是可写流。还有fs
模块,能同时处理可读和可写文件流
可读流和可写流都是单向的,比较容易理解,而另外两个是双向的
1. 双工流
比如说websocket
通信,是一个全双工通信,发送方和接受方都是各自独立的方法,发送和接收都没有任何关系
如下图所示:
基本代码如下:
双工流的演示图如下所示:
除了上述压缩包的例子,还比如一个 babel
,把es6
转换为,我们在左边写入 es6
,从右边读取 es5
基本代码如下所示:
三、应用场景
stream
的应用场景主要就是处理IO
操作,而http
请求和文件操作都属于IO
操作
思想一下,如果一次IO
操作过大,硬件的开销就过大,而将此次大的IO
操作进行分段操作,让数据像水管一样流动,知道流动完成
常见的场景有:
get 请求返回文件给客户端
文件操作
一些打包工具的底层操作
1. get 请求返回文件给客户端
使用stream
流返回文件,res
也是一个stream
对象,通过pipe
管道将文件数据返回
2. 文件操作
创建一个可读数据流readStream
,一个可写数据流writeStream
,通过pipe
管道把数据流转过去
3. 一些打包工具的底层操作
目前一些比较火的前端打包构建工具,都是通过node.js
编写的,打包和构建的过程肯定是文件频繁操作的过程,离不来stream
,如gulp
往期推荐 💐 🌸 🌹 🌻 🌺 🍁
高阅读好文:
【3】Vue内置指令大全
每文一句:少而不学,老而无识。
本次的分享就到这里,如果本章内容对你有所帮助的话欢迎点赞+收藏。文章有不对的地方欢迎指出,有任何疑问都可以在评论区留言。希望大家都能够有所收获,大家一起探讨、进步!
版权声明: 本文为 InfoQ 作者【CoderBin】的原创文章。
原文链接:【http://xie.infoq.cn/article/f77740bcf7d9095e104768237】。文章转载请联系作者。
评论