Nodejs并行异步调用,但具有优先级

时间:2014-07-21 18:25:05

标签: javascript node.js asynchronous parallels

假设我使用Node.js尝试运行两个异步调用来获得一些答案。我知道有一个异步包,你可以在其中传递两个函数和一个可选的回调函数。

async.parallel([fun1(){callback(null,1);},
fun2(){callback(null,2);}],
function(err, results) {  
});

但是假设我现在有一个优先级,如果fun1返回一个值,那么我不需要fun2的答案,只有当fun1返回null时,我才等待fun2。所以我不想使用回调函数,因为回调等待两个函数完成,而fun2可能需要很长时间。

现在我只是通过为异步调用创建回调函数来使用非常详尽的方法。

function(){
    var theAnswer,FromFun1,FromFun2;
    var reply1,reply2;
    fun1(reply1="answered";FromFun1=1;complete());
    fun2(reply2="answered";FromFun2=2;complete());
   function complete(answer){
      if(reply1=="answered"){
           theAnswer=FromFun1;
      }else if(reply1==null){
           // Don't do anything because fun1 is not finished running. 
       }else if(reply2=="answered"){
           theAnswer=FromFun2;
       }else{
           // Both have no answer, err.
       }
   }
}

有更好的方法吗?

2 个答案:

答案 0 :(得分:2)

最好使用瀑布而不是并行执行,因为你可以将前一个函数的结果作为参数传递给下一个函数。

async.waterfall([
function(callback){
    callback(null, 'one');
},
function(arg1, callback){

    // arg1 now equals 'one'
   if(arg1==null){
   // it will not take time it returns immediately 
    callback(null, 'done');

    }else{
    // do your another stuff here fun2 logic here 
    // it will not be executed and so it dont take time 
      }
  }
  ], function (err, result) {
  // result now equals 'done'    
}); 

答案 1 :(得分:2)

我在这个场景中使用的技巧是在回调的第一个参数中返回“done”:

async.parallel([
  function(callback){
    callback("done",1);
  },
  function(callback){
    callback(null,2);
  }
], function(err, results) { 
  console.log(err, results);   // done [ 1 ] or done [ 1 , 2 ] 
});

听起来像是一个黑客,我通常不会这样做,但在一些罕见的情况下,如此,它实际上保持代码清洁...只是记录它,以便其他人知道你的意图。