Post

State 관리와 useState의 중요성

Async-Await와 Promise의 차이

개요

JavaScript에서 비동기 작업을 처리하는 데 있어, Promiseasync-await는 중요한 개념입니다. 이들은 JavaScript의 비동기 처리 패턴을 단순화하고, 코드의 가독성을 향상시킵니다.

Promise

Promise는 JavaScript의 비동기 작업을 위한 객체입니다. Promise는 비동기 작업의 완료 후 결과값을 제공하거나, 발생 가능한 오류를 캡처할 수 있습니다. Promise는 세 가지 상태를 가집니다: 대기(Pending), 이행(Fulfilled), 거부(Rejected).

1
2
3
4
5
6
7
const myPromise = new Promise((resolve, reject) => {
    if (/* 조건 */) {
        resolve('Success');
    } else {
        reject('Error');
    }
});

Promise.then(), .catch(), .finally() 메소드를 통해 연속된 비동기 작업을 체이닝할 수 있습니다. 이는 복잡한 비동기 로직을 구성할 때 유용합니다.

Async-Await

async-await는 ES2017에서 도입된 비동기 처리 문법으로, 내부적으로 Promise를 사용하지만, 동기 코드와 유사한 방식으로 비동기 코드를 작성할 수 있게 해 줍니다. async 함수는 항상 Promise를 반환하고, await 키워드는 Promise가 완료될 때까지 함수 실행을 일시 중지합니다.

1
2
3
4
5
6
7
8
9
async function fetchData() {
  try {
    const response = await fetch("url");
    const data = await response.json();
    return data;
  } catch (error) {
    console.error("Error:", error);
  }
}

차이점

  • 가독성: async-await는 코드의 가독성을 높여줍니다. 복잡한 .then() 체인을 사용하는 대신, 마치 동기 코드처럼 간결하고 이해하기 쉬운 형태로 비동기 코드를 작성할 수 있습니다.
  • 오류 처리: async-await를 사용하면, try-catch 블록을 통해 오류를 더 직관적으로 처리할 수 있습니다. 반면, Promise.catch() 메소드를 사용하여 오류를 처리합니다.
  • 흐름 제어: async-await는 비동기 함수 내에서 조건문, 반복문 등을 사용할 때 흐름 제어가 더욱 용이합니다.

결론

async-awaitPromise는 JavaScript에서 비동기 프로그래밍을 구현하는 데 있어 강력한 도구입니다. 각각의 사용법과 특성을 이해하고 상황에 맞게 적절히 사용하는 것이 중요합니다.

This post is licensed under CC BY 4.0 by the author.