async.series和async.parallel有什么区别。考虑下面的例子,我得到了相同的结果。
async.parallel([ function(callback){ setTimeout(function(){ callback(null, 'one'); }, 200); }, function(callback){ setTimeout(function(){ callback(null, 'two'); }, 100); }, function(callback){ setTimeout(function(){ var err = new Error('I am the error'); callback(err); }, 400); }, function(callback){ setTimeout(function(){ callback(null, 'three'); }, 600); }, ], // optional callback function(err, results){ if(err){ console.log('Error'); } else { } console.log(results); //results is now equal to [ 'one', 'two', undefined ] // the second function had a shorter timeout. });
和
async.series([ function(callback){ setTimeout(function(){ callback(null, 'one'); }, 200); }, function(callback){ setTimeout(function(){ callback(null, 'two'); }, 100); }, function(callback){ setTimeout(function(){ var err = new Error('I am the error'); callback(err); }, 400); }, function(callback){ setTimeout(function(){ callback(null, 'three'); }, 600); } ], // optional callback function(err, results){ //results is now equal to [ 'one', 'two', undefined ] if(err){ console.log('Error'); } else { } console.log(results); });
我看不出有什么区别。也许我的样品不好?我在github异步存储库上阅读了有关这两个函数的文档,可以找到async.parallel函数:
如果任何函数将错误传递到其回调,则立即使用错误的值调用主回调
async.parallel中的主要回调是什么?
async.series依次调用您的函数(等待前面的每个函数完成,然后再开始下一个)。async.parallel将同时启动它们(或者无论如何在单线程区域同时启动它们)。
async.series
async.parallel
主回调是对async.parallel或的调用中可选提供的回调async.series(签名为async.parallel(tasks, [callback]))
async.parallel(tasks, [callback])
所以实际上是这样的:
parallel
[ , "Two"]
["One", "Two"]
undefined
["One", "Two", undefined]
series
["One"]
您获得相同结果的事实是由于您依赖于setTimeout任务。
setTimeout
至于如何parallel有效地使用,请尝试使用下载一百个网页parallel。然后使用series。走着瞧吧。