개요
자바스크립트에서 비동기 작업을 처리하기 위해 프라미스(Promise)라는 개념을 사용할 수 있습니다. 프라미스는 비동기 작업의 결과를 나타내는 객체로, 성공한 경우 성공한 값을 반환하고 실패한 경우 실패한 이유를 반환합니다. 프라미스는 동시성 처리를 위해 사용되며, 여러 개의 비동기 작업을 동시에 실행하고 결과를 취합하는데 유용합니다.
프라미스의 생성
프라미스는 new Promise()
를 사용하여 생성할 수 있습니다. 생성자 함수는 하나의 콜백 함수를 인수로 받으며, 이 콜백 함수는 resolve
와 reject
라는 두 개의 인수를 가집니다. resolve
는 성공한 경우에 호출되며 성공한 값을 반환합니다. reject
는 실패한 경우에 호출되며 실패한 이유를 반환합니다.
const promise = new Promise((resolve, reject) => {
// 비동기 작업 수행
// 성공한 경우 resolve 호출
// 실패한 경우 reject 호출
});
프라미스 체이닝
프라미스는 체이닝을 통해 여러 개의 비동기 작업을 순차적으로 실행하고 결과를 전달할 수 있습니다. 프라미스 체이닝은 then()
과 catch()
메서드를 사용하여 구현됩니다. then()
은 성공한 경우에 호출되며 다음 프라미스를 반환합니다. catch()
는 실패한 경우에 호출되며 실패한 이유를 처리합니다.
promise
.then(result => {
// 이전 프라미스에서 반환된 성공한 값(result)을 가지고 작업을 수행
// 다음 프라미스를 반환
})
.then(result => {
// 이전 프라미스에서 반환된 값(result)을 가지고 작업을 수행
// 다음 프라미스를 반환
})
.catch(error => {
// 이전 프라미스에서 발생한 실패한 이유(error)를 처리
});
동시성 처리
프라미스를 사용하면 여러 개의 비동기 작업을 동시에 실행하고 모든 작업이 완료될 때까지 기다릴 수 있습니다. Promise.all()
메서드를 사용하여 여러 개의 프라미스를 배열로 전달하면, 모든 프라미스가 성공한 경우에는 성공한 값들의 배열을 반환하고, 하나라도 실패한 경우에는 실패한 이유를 반환합니다.
const promises = [
promise1,
promise2,
promise3
];
Promise.all(promises)
.then(results => {
// 모든 프라미스가 성공한 경우에는 성공한 값들의 배열(results)을 가지고 작업을 수행
})
.catch(error => {
// 하나라도 실패한 경우에는 실패한 이유(error)를 처리
});
결론
자바스크립트 프라미스를 사용하여 동시성 처리를 할 수 있습니다. 프라미스는 비동기 작업의 결과를 처리하기 위한 효과적인 도구로, 프라미스 체이닝을 통해 여러 개의 비동기 작업을 순차적으로 실행하고 결과를 전달할 수 있습니다. 프라미스를 사용하여 여러 개의 비동기 작업을 동시에 실행하고 결과를 취합할 수도 있습니다. 이러한 기능을 활용하여 자바스크립트에서 동시성 처리를 보다 쉽고 효율적으로 구현할 수 있습니다.