개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.05.09 04:06

async function myFunc() {}의 비동기 처리 이해

목록
  • 웹접근성장인 12일 전 2025.05.09 04:06
  • 35
    1
제가 async function myFunc() {}를 공부 중인데, 비동기 처리에 대해 이해가 잘 안 가는 부분이 있습니다.

비동기 처리는 어떻게 동작하는지에 대해 설명해 주실 수 있나요?

예를 들어 async function myFunc() {} 내부에서 setTimeout() 함수를 사용할 때, 비동기 처리가 어떻게 작동하는지 설명해 주실 수 있나요?

이러한 예시를 통해 비동기 처리에 대한 이해를 도와주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  12일 전

    비동기 처리는 함수의 실행을 다른 스레드나 프로세스에 위임하여, 함수의 실행이 완료되지 않은 상태에서도 다음 코드를 실행할 수 있도록 하는 기술입니다.

    async function myFunc() {} 내부에서 setTimeout() 함수를 사용할 때, 비동기 처리가 작동하는 방식은 다음과 같습니다.

    1. setTimeout() 함수는 함수의 실행을 일정 시간 뒤에 다른 스레드에 위임합니다.
    2. setTimeout() 함수가 위임한 스레드는 setTimeout() 함수의 시간이 지난 후에 함수를 실행합니다.
    3. 함수의 실행이 완료되지 않은 상태에서도 setTimeout() 함수가 위임한 스레드는 다음 코드를 실행할 수 있습니다.
    4. async function myFunc() {} 내부에서 setTimeout() 함수를 사용하면, setTimeout() 함수가 위임한 스레드가 함수를 실행하는 동안, async function myFunc() {} 내부의 다른 코드를 실행할 수 있습니다.

    예를 들어, 다음 코드를 살펴보겠습니다.

    #hostingforum.kr
    javascript
    
    async function myFunc() {
    
      console.log('1');
    
      setTimeout(() => {
    
        console.log('2');
    
      }, 1000);
    
      console.log('3');
    
    }
    
    
    
    myFunc();
    
    


    이 코드를 실행하면, 다음 순서로 실행됩니다.

    1. console.log('1');이 실행됩니다.
    2. setTimeout() 함수가 위임한 스레드가 setTimeout() 함수의 시간을 기다립니다.
    3. setTimeout() 함수의 시간이 지난 후, setTimeout() 함수가 위임한 스레드가 console.log('2');을 실행합니다.
    4. console.log('3');이 실행됩니다.

    이 예시를 통해, async function myFunc() {} 내부에서 setTimeout() 함수를 사용할 때, 비동기 처리가 작동하는 방식을 이해할 수 있습니다.

    2025-05-09 04:07

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 21,049건 / 5 페이지

검색

게시물 검색