我一直试图围绕我的问题,但没有成功,因此我要求你的帮助。异步代码执行说明
让我们看看下面的例子:
const async = require('async')
var counter = 0
var test = cb => {
if (++counter < 3) {
setTimeout(() => {
async.each([0,1,2], (item, callback) => {
console.log(item)
console.log('counter inner ' + counter)
test(cb)
callback()
},() => {
cb()
})
})
} else {
console.log('counter ' + counter)
}
}
var prom = new Promise((res, rej) => test(() => res('done')))
prom.then(res => console.log(res))
输出是:
0
counter inner 1
1
counter inner 2
counter 3
2
counter inner 3
counter 4
done
0
counter inner 4
counter 5
1
counter inner 5
counter 6
2
counter inner 6
counter 7
我不明白的是它是如何在第二0
后立即打印counter inner 4
。不应该打印counter inner 1
?一个承诺只能解决一次?第二次解决呼叫会发生什么?谢谢。
可能的重复[为什么我的变量在函数内部修改后没有改变? - 异步代码引用](https://stackoverflow.com/questions/23667086/why-is-my-variable-unaltered-after-i-modify-it-inside-of-a-function-asynchron) – Liam
* [One单词答案:异步性。](https://stackoverflow.com/a/23667087/542251)* – Liam