为什么Array.map Array.forEach异步操作需要Promise.all?

我正在使用NodeJS(ExpressJS)服务器,具有以下代码:

let caseScore = 0
await questions.map(async q => {
  caseScore += await q.grade() // Queries database and gets questions, finds score
}))
console.log(caseScore)
>> Output: 0

但是,似乎q.grade()在请求完成后完成执行。我将console.log()放在q.grade中,它在发送响应后显示。显然,这是异步执行的。所以后来我这样做了:

let caseScore = 0
await Promise.all(questions.map(async q => {
  caseScore += await q.grade() // Queries database and gets questions, finds score
})))
console.log(caseScore)
>> Output: 2

它运作完美。有人可以向我解释为什么需要Promise.all吗?另外,如果我将.map更改为.forEach,Promise.all错误,那么对.forEach进行此更改的正确方法是什么?

评论
BOSS
BOSS

因为下面的以下表达式返回Promise []。

questions.map(async q => {
  caseScore += await q.grade() // Queries database and gets questions, finds score
}))

Awaiting Promise[] will not wait for execution. But Promise.all will convert Promise[] to Promise.

点赞
评论
Lee
Lee

您应该等待所有异步调用完成。这就是为什么promise.all需要的原因。

它将承诺集合转换为单个承诺。

点赞
评论