转载地址:http://blog.csdn.net/vieri_32/article/details/48376547

前言

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

通过nodeschool学习stream

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

简单stream进行pipe

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

process.stdin.pipe(process.stdout)
process.stdin.pipe(fs.createWriteStream(path))
fs.createReadStream(path).pipe(process.stdin)

pipe中间进行处理

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

var through2  = require('through2');
var stream = through2(write,end)
process.stdin
.pipe(stream)
.pipe(process.stdout); function write(line,_,next){
this.push(line.toString().toUpperCase())
next();
})
function end(done){
done();
})

stream转化成普通回调

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

var concat = require('concat-stream');

var reverseStream=concat(function(text){
console.log(text.toString().split("").reverse().join(""));
}) process.stdin.pipe(reverseStream)

http server中的流

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

var http = require('http');
var server = http.createServer(function(req,res){
req.pipe(res);
})

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

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

var request = require('request');
var r = request.post('http://localhost:8099');
process.stdin.pipe(r).pipe(process.stdout)

分支管道

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

var trumpet = require('trumpet');
var through2 = require('through2');
var fs = require('fs');
var tr = trumpet();
var stream = tr.select('.loud').createStream();
var upper = through2(function(buf,_,next){
this.push(buf.toString().toUpperCase());
next();
})
stream.pipe(upper).pipe(stream);
process.stdin.pipe(tr).pipe(process.stdout);

合并输入输出stream例子

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

var spawn = require('child_process').spawn;
var duplexer2 = require('duplexer2'); module.exports = function(cmd, args){
var c = spawn(cmd,args)
return duplexer2(c.stdin,c.stdout)
}

总结

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

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

最新文章

  1. const,static,extern 简介
  2. 我的MYSQL学习心得(九) 索引
  3. The Coroutine
  4. JSON帮助类
  5. 使用Sqlserver更新锁防止数据脏读
  6. magento的url中 去掉多余的目录层级
  7. 一个简单的linux线程池(转-wangchenxicool)
  8. struts2 I18n问题 国际化
  9. Ajax在PC端可以使用但在手机端不能使用
  10. JavaScript压缩混淆 / 格式化 / 美化工具 - aTool在线工具
  11. python的filter()函数
  12. :before :after
  13. 使用开源的PullToRefreshScrollView scrollTo和scrollby遇到的问题
  14. (六)javascriptJS中定义对象的几种方式(转)
  15. LInux命令英文全称
  16. 【AtCoder】AGC032
  17. Codeforces Round #553 (Div. 2)B. Dima and a Bad XOR 思维构造+异或警告
  18. arcgis 加载高德地图 es6的方式
  19. Cosplay之孩子的妈咪
  20. vue 生命周期 笔记

热门文章

  1. C# checked运算符
  2. java基础面试题:写clone()方法时,通常都有一行代码,是什么?
  3. 单片机入门学习笔记5:STC下载器
  4. 并查集:HDU5326-Work(并查集比较简单灵活的运用)
  5. HDU1301 Jungle Roads
  6. WPF学习笔记(8):DataGrid单元格数字为空时避免验证问题的解决
  7. 第三模块 面向对象& 网络编程基础 实战考核
  8. HTML练习题
  9. vrpie在Visio Studio 中无法调试的问题
  10. 免费生成https证书以及配置