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.parallel
或的调用中可选提供的回调async.series
(签名为async.parallel(tasks, [callback])
)
所以实际上是这样的:
parallel
启动所有任务,然后等待[ , "Two"]
)["One", "Two"]
)undefined
结果(结果为["One", "Two", undefined]
)parallel
发现错误,立即返回到目前为止收到的结果series
触发第一个任务;它计划超时。series
等到回调在200毫秒后被调用,然后添加结果。(结果为["One"]
)series
触发第二项任务;它计划超时。series
等到回调在100毫秒后被调用,然后添加结果。(结果为["One", "Two"]
)series
发射第三项任务;它计划超时。series
等到回调在400ms后被调用,然后添加结果并由于错误而退出。(结果为["One", "Two", undefined]
)您获得相同结果的事实是由于您依赖于setTimeout
任务。
至于如何parallel
有效地使用,请尝试使用下载一百个网页parallel
。然后使用series
。走着瞧吧。
问题内容: nodejs异步模块:https : //github.com/caolan/async提供2 种类似的方法,和。 它们之间有什么区别? 问题答案: 似乎允许每个函数将其结果传递给下一个函数,同时将所有结果传递给最终的回调。在更高级别上,将用于数据管道(“给定2,将其乘以3,再加2,并除以17”),而对于必须按顺序执行但又分开的离散任务。
问题内容: 我错放了太多次了,我想我一直忘记,因为我不知道两者之间的区别,只是一个给了我我期望的价值,而另一个却没有。 为什么是这样? 问题答案: 是的简写形式(尽管请注意,该表达式只会被计算一次。) 是的,即指定一元的到。 例子:
问题内容: 因此,我有一段简单的代码可以打印出整数1-10: 然后,如果仅在第3行上更改一个运算符,它将打印出无限数量的1整数(我知道为什么会这样做)。为什么在运行第二个程序时没有出现语法错误?如果赋值运算符后面跟着一个加法运算符,它不会调用语法错误吗? 问题答案: 与相同, 只是意味着。
问题内容: 有人可以解释一下 和 我不知道“确切”的含义 问题答案: 在这个例子中,什么都没有。当您具有多个具有相似名称的路径时,该参数将起作用: 例如,假设我们有一个显示用户列表的组件。我们还有一个用于创建用户的组件。的网址应嵌套在下。因此,我们的设置可能如下所示: 现在,这里的问题是,当我们转到路由器时,将通过所有定义的路由,并返回它找到的第一个匹配项。因此,在这种情况下,它将首先找到路线,然
问题内容: 我很好奇printStackTrace()和toString()之间的区别是什么。乍一看,他们 似乎 做的完全相同。 码: 问题答案: 不,有重要区别!使用toString,您只有异常的类型和错误消息。使用printStackTrace()可以获得异常的整个堆栈跟踪,这对于调试非常有帮助。 System.out.println(toString())的示例: printStackTra