>웹 프론트엔드 >JS 튜토리얼 >Promise.all() 대 다중 대기: JavaScript에서 동시 호출과 순차 비동기 호출을 언제 사용해야 합니까?

Promise.all() 대 다중 대기: JavaScript에서 동시 호출과 순차 비동기 호출을 언제 사용해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-01 22:56:15810검색

Promise.all() vs. Multiple Awaits: When to Use Concurrent vs. Sequential Async Calls in JavaScript?

동시 호출과 순차 비동기 호출: Promise.all()과 다중 대기

JavaScript에서 개발자는 종종 비동기 함수를 사용하여 다음을 방지합니다. 메인 스레드를 차단하고 성능을 향상시킵니다. 비동기 작업을 처리하는 두 가지 일반적인 패턴은 Promise.all()과 여러 wait 문을 사용하는 것입니다.

1. Promise.all()

Promise.all([promise1, promise2, ...])은 Promise 배열을 가져와 모든 입력 Promise가 해결되면 해결되는 새 Promise를 반환합니다. 또는 거부됨). 이를 통해 여러 비동기 작업이 동시에 완료될 때까지 기다릴 수 있습니다.

2. 다중 대기

여러 대기 문을 사용하면 비동기 작업을 차례로 기다릴 수 있습니다. 이는 작업을 효과적으로 직렬화하여 순차적으로 실행합니다.

타이밍 차이

Promise.all()과 다중 Wait 문의 주요 차이점은 타이밍에 있습니다. Promise.all()은 모든 비동기 작업을 동시에 시작하고 여러 개의 wait 문이 이를 한 번에 하나씩 실행합니다.

이러한 타이밍 차이는 일부 비동기 작업이 다른 작업보다 훨씬 오래 걸리는 시나리오에서 성능에 영향을 미칠 수 있습니다. 이러한 경우 Promise.all()을 사용하면 동시성을 활용하여 성능을 향상시킬 수 있습니다.

다음 코드 조각을 고려하세요.

const res = (ms) => new Promise((resolve, reject) => setTimeout(resolve, ms));

const example = async () => {
  const start = Date.now();
  const data = await Promise.all([res(3000), res(2000), res(1000)]);
  console.log(`Promise.all finished after: ${Date.now() - start}ms`);
};

example();

이 코드를 실행하면 세 가지 비동기 작업(3000만큼 지연됨, 2000 및 1000밀리초)가 동시에 실행됩니다. 결과적으로 Promise.all은 세 가지 작업이 모두 완료된 후에만 확인되며 결과는 함수 시작 후 3000밀리초 후에 기록됩니다.

위 내용은 Promise.all() 대 다중 대기: JavaScript에서 동시 호출과 순차 비동기 호출을 언제 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.