JavaScript Promises 本身并不直接支持并发,它们主要用于处理异步操作并确保按照预期的顺序执行。然而,您可以使用 Promise.all()
方法来实现一定程度的并发。Promise.all()
接收一个 Promise 数组作为参数,并在所有 Promise 都成功完成时返回一个新的 Promise。如果其中任何一个 Promise 失败,它将立即拒绝并返回第一个失败的 Promise 的原因。
以下是一个使用 Promise.all()
实现并发的示例:
const asyncTask1 = () => { return new Promise((resolve, reject) => { setTimeout(() => { resolve('Task 1 completed'); }, 1000); }); }; const asyncTask2 = () => { return new Promise((resolve, reject) => { setTimeout(() => { resolve('Task 2 completed'); }, 2000); }); }; const asyncTask3 = () => { return new Promise((resolve, reject) => { setTimeout(() => { resolve('Task 3 completed'); }, 3000); }); }; Promise.all([asyncTask1(), asyncTask2(), asyncTask3()]) .then((results) => { console.log(results); // ['Task 1 completed', 'Task 2 completed', 'Task 3 completed'] }) .catch((error) => { console.error(error); });
在这个示例中,我们定义了三个异步任务(asyncTask1
、asyncTask2
和 asyncTask3
),它们分别在 1 秒、2 秒和 3 秒后完成。通过将这三个任务放入一个数组中并将它们传递给 Promise.all()
,我们可以并发地执行它们。当所有任务都成功完成时,我们将收到一个包含所有任务结果的数组。如果有任何任务失败,我们将立即收到错误信息。