동시 호출과 순차 비동기 호출: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!