位置: - 正文

理解nodejs的stream和pipe机制的原理和实现(nodejs dgram)

编辑:rootadmin

推荐整理分享理解nodejs的stream和pipe机制的原理和实现(nodejs dgram),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs stdout,nodejs详解,node.js的理解,nodejs writestream,nodejs stdin,nodejs stdin,nodejs stream原理,node.js stream,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

前几天别人请教我关于pipe的问题,我发现我虽然用了nodejs很久,但是由于每次用的不多所以经常回避stream的使用,导致一直不熟,现在重新学习整理一下相关知识。

通过nodeschool学习stream

nodeschool有一个stream-adventure教程教导stream的使用,很简单

简单stream进行pipe

首先,我们可以通过管道将输入定位到输出,输入输出可以是控制台或者文件流或者http请求,比如

pipe中间进行处理

如果我们想要在管道中间进行处理,比如想将输入的字符串变成大写写到输出里,我们可以使用一些可以作为中间处理的框架,比如through2就很方便

理解nodejs的stream和pipe机制的原理和实现(nodejs dgram)

stream转化成普通回调

当我们输入是流,而输出是个普通函数,我们需要把输入流转化为普通的buffer,这时可以试用concat-stream库

http server中的流

类似stdin和fs,http由于其特性也适合使用流,所以其自带类似特性

既作为输入也作为输出的流

request框架实现了如下功能,将一个流pipe到request请求中,然后将流的内容发给服务器,然后返回作为流供其他代码使用,实现如下

分支管道

下边是一个例子,这个例子将输入管道中html包含loud class的元素放入另一个管道进行大写操作,然后最后合并成输出

合并输入输出stream例子

合并后的输入输出可像前文request一样使用,下边这个例子实现了使用流的方式进行子进程调用

总结

通过上边的例子,可以知道stream应该还有如何合并等更复杂的应用方式。总之整体上符合如下特性:

Stream分为readable、writeble Stream通过pipe方法控制流向 httpServer和httpClient和file system和process.stdinouterr通常可以作为stream Stream可以被on(event)转化为普通的变量,普通变量可以被write转换成stream Stream自身可以被拆分、合并、过滤

本文链接地址:https://www.jiuchutong.com/biancheng/380928.html 转载请保留说明!
下一篇链接:https://www.jiuchutong.com/biancheng/380929.html
免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

鄂ICP备2023003026号

友情链接: 武汉网站建设 电脑维修 湖南楚通运网络