상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
궁금한 상식 보기
글루텐 프리 디저트는 어떻게 만들 수 있나요?
디저트의 프레젠테이션을 위한 그릇 선택은?
디저트의 조리법을 쉽게 이해하는 방법은?
독립 선언의 주요 내용이 다른 문서에 영향을 미친 사례는 무엇인가요?
제1차 세계 대전에서의 전투에서의 군사 전술의 변화는 어떤 것이 있었나요?
행정부의 권한은 무엇인가요?
헌법에서 '연방주의'의 개념은 무엇인가요?
제2차 세계 대전에서의 전투에서의 전투의 전개 과정에서의 주요 전술은 무엇이었나요?
베트남 전쟁에서의 '전쟁의 기억의 인종적 차원'은 무엇인가요?
코나 커피의 커피 관련 포럼은 어디에 있나요?
얼굴 인식 기술의 원리는 무엇인가요?
15세기 동안의 주요 문학 장르는 무엇이었나요?
Previous
Next
수정하기 - 자바스크립트에서 함수의 비동기 처리 패턴은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
자바스크립트에서 <a href='https://sangseek.com/sangseeks/비동기 처리/ko'>비동기 처리</a>는 웹 개발에서 매우 중요한 개념입니다. 비동기 처리는 코드의 실행 흐름이 중단되지 않고, 다른 작업을 수행할 수 있도록 해줍니다. 이는 특히 네트워크 요청, 파일 읽기, 타이머 등 시간이 걸리는 작업을 처리할 때 유용합니다. 자바스크립트에서 비동기 처리를 위한 여러 가지 패턴이 존재하며, 이를 통해 개발자는 효율적이고 반응성이 뛰어난 애플리케이션을 만들 수 있습니다. 1. 콜백(Callback) 가장 기본적인 비동기 처리 패턴은 콜백 함수입니다. 콜백은 특정 작업이 완료된 후 호출되는 함수로, 비동기 작업의 결과를 처리하는 데 사용됩니다. 예를 들어, `setTimeout` 함수를 사용하여 일정 시간이 지난 후에 실행되는 코드를 작성할 수 있습니다. ```javascript console.log("Start"); setTimeout(() => { console.log("Timeout finished"); }, 1000); console.log("End"); ``` 위 코드를 실행하면 "Start"와 "End"가 먼저 출력되고, 1초 후에 "Timeout finished"가 출력됩니다. 그러나 콜백 패턴은 여러 개의 비동기 작업이 중첩될 경우 "<a href='https://sangseek.com/sangseeks/콜백 지옥/ko'>콜백 지옥</a>"이라고 불리는 가독성이 떨어지는 코드가 발생할 수 있습니다. 2. <a href='https://sangseek.com/sangseeks/프로미스/ko'>프로미스</a>(Promise) 콜백의 단점을 보완하기 위해 ES6에서 도입된 프로미스는 비동기 작업의 결과를 나타내는 객체입니다. 프로미스는 세 가지 상태를 가집니다: 대기(pending), 이행(fulfilled), <a href='https://sangseek.com/sangseeks/거부/ko'>거부</a>(<a href='https://sangseek.com/sangseeks/rejected/ko'>rejected</a>). 프로미스를 사용하면 비동기 작업의 결과를 더 깔끔하게 처리할 수 있습니다. ```javascript const myPromise = new Promise((resolve, reject) => { setTimeout(() => { resolve("Promise resolved"); }, 1000); }); myPromise .then(result => { console.log(result); }) .catch(error => { console.error(error); }); ``` 위 코드에서 `myPromise`는 1초 후에 "Promise resolved"라는 메시지를 출력합니다. 프로미스를 사용하면 `.then()`과 `.catch()` 메서드를 통해 결과를 처리할 수 있어 코드가 더 깔끔해집니다. 3. async/await <a href='https://sangseek.com/sangseeks/ES2017/ko'>ES2017</a>에서 도입된 `async/await`는 프로미스를 기반으로 한 비동기 처리의 더 간결한 방법입니다. `async` 키워드를 사용하여 비동기 함수를 정의하고, `await` 키워드를 사용하여 프로미스가 이행될 때까지 기다릴 수 있습니다. ```javascript const myAsyncFunction = async () => { try { const result = await myPromise; console.log(result); } catch (error) { console.error(error); } }; myAsyncFunction(); ``` `async/await`를 사용하면 비동기 코드를 동기 코드처럼 작성할 수 있어 가독성이 크게 향상됩니다. 또한, 에러 처리를 위해 `try/catch` 블록을 사용할 수 있어 더욱 직관적입니다. 4. 비동기 이터레이터(Async Iterators) ES2018에서 도입된 비동기 이터레이터는 비동기 데이터 스트림을 처리하는 데 유용합니다. 비동기 이터레이터는 `for await...of` 구문을 사용하여 비동기적으로 데이터를 반복 처리할 수 있습니다. ```javascript async function* asyncGenerator() { for (let i = 0; i < 5; i++) { await new Promise(resolve => setTimeout(resolve, 1000)); yield i; } } (async () => { for await (const value of asyncGenerator()) { console.log(value); } })(); ``` 위 코드에서 `asyncGenerator`는 1초마다 값을 생성하며, `for await...of`를 사용하여 이 값을 비동기적으로 반복 출력합니다. 결론 자바스크립트에서 비동기 처리는 다양한 패턴을 통해 구현할 수 있으며, 각 패턴은 특정 상황에 적합합니다. 콜백은 간단한 비동기 작업에 유용하지만, 복잡한 로직에서는 가독성이 떨어질 수 있습니다. 프로미스는 비동기 작업의 결과를 더 명확하게 처리할 수 있게 해주며, `async/await`는 이를 더욱 간결하게 만들어 줍니다. 비동기 이터레이터는 비동기 데이터 스트림을 처리하는 데 유용합니다. 이러한 비동기 처리 패턴을 적절히 활용하면, 자바스크립트 애플리케이션의 성능과 사용자 경험을 크게 향상시킬 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기