大佬教程收集整理的这篇文章主要介绍了什么是Node.js中的Streams3,它与Streams2有什么不同?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我在哪里可以阅读它,以及Streams2和Streams3之间的区别。
在Google上做搜索,我也看到它在Changelog of Node 0.11.5提到,
不幸的是,要理解任何定义Streams3的描述,你需要先了解Streams1和遗留流
背景
首先,让我们来看看Node v0.10.25文档对这两种模式的看法,
Isaac Z. Schlueter said in November slides I dug up:
所以看起来像在streams1,你将创建一个对象,并调用.on(‘data’,cb)到该对象。这将设置事件被触发,然后你在流的怜悯。在Streams2中,内部流有缓冲区,并且显式地从这些流请求数据(使用`.read)。 Isaac继续指定如何向后兼容在Streams2中工作,以保持Streams1(旧流)模块运行
因此,在Streams2中,对.pause()或.resume()的调用触发垫片。而且,它应该,对吧?在Streams2你可以控制什么时候.read(),你不会捕捉的东西被抛在你。这触发了独立于Streams2操作的传统模式。
让我们以Isaac的幻灯片为例,
createServer(function(q,s) { // ADVISORY only! q.pause() session(q,function(ses) { q.on('data',handler) q.resume() }) })
>在Streams1中,q立即启动读取和发出(可能丢失数据),直到调用q.pause建议q停止提取数据,但不是从发出事件清除已经读取的数据。>在Streams2中,q暂停,直到对表示模拟旧模式的.pause()调用。>在Streams3中,q从暂停状态开始,从未从文件句柄读取,使q.pause()成为noop,并且在调用q.on(‘data’,cb)时将调用q.resume,直到没有更多的数据在缓冲区。然后,再次调用q.resume做同样的事情。
以上是大佬教程为你收集整理的什么是Node.js中的Streams3,它与Streams2有什么不同?全部内容,希望文章能够帮你解决什么是Node.js中的Streams3,它与Streams2有什么不同?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。