NodeJS - 在.on('可读')事件中读取可读流数据时,为什么还要使用while循环

时间:2015-07-30 01:08:18

标签: node.js stream

这种从可读流中读取数据的方式有什么好处:

request.on('readable', function(){
    var chunk = null;
    while (null !== (chunk = request.read())) {
        response.write(chunk);
    };
});

vs这种没有while循环的方式?因为'可读'会继续解雇为什么还要打扰while循环?

request.on('readable', function(){
    var chunk = request.read();
    if(chunk !== null){
        response.write(chunk);          
    }
});

1 个答案:

答案 0 :(得分:1)

根据API文档:

var req = http.request(options, function(res) {
  console.log('STATUS: ' + res.statusCode);
  console.log('HEADERS: ' + JSON.stringify(res.headers));
  res.setEncoding('utf8');
  res.on('data', function (chunk) {
    console.log('BODY: ' + chunk);
  });
});

使用res.on('数据')事件,您可以在准备好时获取数据。这将允许您的程序继续前进并执行其他操作,直到准备好处理下一个数据块(请记住HTTP是通过TCP进行分块)。

使用下面的代码可能会有效,但是为什么在它不必要地占用CPU周期并阻止其他代码执行时呢(请记住你的Node.js JavaScript代码是单线程的)。使用事件要好得多,因为它允许JavaScript运行并处理输入/输出而不会不必要地阻塞进程。

request.on('readable', function(){
    var chunk = null;
    while (null !== (chunk = request.read())) {
        response.write(chunk);
    };
});