并发等待操作执行
相关代码片段在执行异步操作时遇到问题:
;<br>const value1 = wait getValue1Async();<br>const value2 = wait getValue2Async();<br>
此实现顺序等待每个操作完成,然后再开始下一个操作。要启用并发执行,需要一种修改方法。
第一个解决方案尝试通过获取每个操作的 Promise,然后分别等待它们来解决此问题:
<br>const p1 = getValue1Async();<br>const p2 = getValue2Async();<br>const value1 = wait p1;<br>const value2 = wait p2;<br>
虽然此方法确实并行运行两个操作,但它不处理如果两个承诺都拒绝,则正确拒绝。它还会等待第一个操作完成后才开始第二个操作,效率很低。
要解决这些问题,可以使用 Promise.all 函数:
<br>const [value1, value2] = wait Promise.all([getValue1Async(), getValue2Async()]);<br>
Promise.all 接受一个 Promise 数组,并返回一个在所有输入 Promise 都已解决或拒绝时解析的 Promise。这种方法有几个优点:
综上所述,要执行并发异步操作,正确的拒绝处理、使用Promise.all:
<br>const [value1, value2] = wait Promise.all([getValue1Async(), getValue2Async()]);<br>
以上是如何在 JavaScript 中同时运行异步操作并进行适当的错误处理?的详细内容。更多信息请关注PHP中文网其他相关文章!