> 웹 프론트엔드 > JS 튜토리얼 > Node.js의 콜백 큐에 대한 심층 분석

Node.js의 콜백 큐에 대한 심층 분석

青灯夜游
풀어 주다: 2020-09-01 10:39:06
앞으로
1677명이 탐색했습니다.

Node.js의 콜백 큐에 대한 심층 분석

Queue는 비동기 작업을 효율적으로 처리하기 위한 Node.js의 중요한 기술입니다. [동영상 튜토리얼 권장 사항: node js tutorial ]

이 기사에서는 Node.js의 대기열이 무엇인지, 대기열이 어떻게 작동하는지(이벤트 루프를 통해) 및 유형에 대해 자세히 알아볼 것입니다.

Node.js의 대기열이란 무엇인가요?

Queue는 Node.js에서 비동기 작업을 구성하는 데 사용되는 데이터 구조입니다. 이러한 작업은 HTTP 요청, 파일 읽기 또는 쓰기 작업, 스트림 등을 포함하여 다양한 형태로 존재합니다.

Node.js에서 비동기 작업을 처리하는 것은 매우 어렵습니다.

네트워크 품질에 따라 HTTP 요청 중에 예측할 수 없는 지연(또는 더 나쁜 경우, 결과 없음)이 발생할 수 있습니다. 파일 크기에 따라 Node.js로 파일을 읽고 쓰려고 할 때 지연이 발생할 수도 있습니다.

타이머 및 기타 여러 작업과 마찬가지로 비동기 작업의 완료 시간도 불확실할 수 있습니다.

이러한 다양한 대기 시간 시나리오에서 Node.js는 이러한 모든 작업을 효율적으로 처리할 수 있어야 합니다.

Node.js는 첫 시작 첫 핸들(첫 시작 첫 핸들) 또는 첫 마무리 첫 핸들(첫 완료 첫 핸들)을 기반으로 하는 작업을 처리할 수 없습니다.

이 작업을 수행할 수 없는 이유 중 하나는 하나의 비동기 작업에 다른 비동기 작업이 포함될 수도 있다는 것입니다.

첫 번째 비동기 프로세스를 위한 공간을 만든다는 것은 대기열의 다른 비동기 작업을 고려하기 전에 내부 비동기 프로세스가 완료되어야 함을 의미합니다.

고려해야 할 상황이 많기 때문에 가장 좋은 선택은 규칙을 만드는 것입니다. 이 규칙은 Node.js에서 이벤트 루프와 큐가 작동하는 방식에 영향을 미칩니다.

Node.js가 비동기 작업을 처리하는 방법을 간략하게 살펴보겠습니다.

콜 스택, 이벤트 루프 및 콜백 큐

콜 스택은 현재 실행 중인 함수와 함수가 시작된 위치를 추적하는 데 사용됩니다. 함수가 실행되려고 하면 호출 스택에 추가됩니다. 이는 JavaScript가 함수 실행 후 처리 단계를 재추적하는 데 도움이 됩니다.

콜백 큐는 백그라운드 작업이 완료되면 콜백 함수를 비동기 작업으로 저장하는 큐입니다. FIFO(선입선출) 방식으로 작동합니다. 이 문서의 뒷부분에서 다양한 유형의 콜백 대기열을 소개하겠습니다.

JavaScript는 단일 스레드 특성을 활용하여 새 스레드가 생성되는 것을 방지할 수 있으므로 Node.js가 모든 비동기 활동을 담당한다는 점에 유의하세요.

백그라운드 작업을 완료한 후 콜백 대기열에 기능을 추가하는 역할도 담당합니다. JavaScript 자체는 콜백 대기열과 아무 관련이 없습니다. 동시에 이벤트 루프는 콜백 큐에서 함수를 추출하여 콜 스택에 추가할 수 있도록 콜 스택이 비어 있는지 지속적으로 확인합니다. 이벤트 루프는 모든 동기화 작업이 수행된 후에만 큐를 확인합니다.

그렇다면 이벤트 루프는 어떤 순서로 대기열에서 콜백 함수를 선택합니까?

먼저 5가지 주요 콜백 대기열 유형을 살펴보겠습니다.

콜백 큐의 종류

IO 큐(IO 큐)

IO 작업은 외부 장치(예: 컴퓨터 하드 디스크, 네트워크 카드 등)와 관련된 작업을 의미합니다. 일반적인 작업에는 파일 읽기 및 쓰기 작업, 네트워크 작업 등이 포함됩니다. 이러한 작업은 처리를 Node.js에 맡기므로 비동기식이어야 합니다.

JavaScript는 컴퓨터의 내부 장치에 액세스할 수 없습니다. 이러한 작업이 수행되면 JavaScript는 백그라운드에서 처리하기 위해 이를 Node.js로 전송합니다.

완료 후에는 이벤트 루프가 실행을 위해 호출 스택으로 전송되도록 IO 콜백 큐로 전송됩니다.

Timer queue

Node.js 타이머 함수(예: setTimeout()setInterval())와 관련된 모든 작업은 타이머 대기열에 추가됩니다. . setTimeout()setInterval())都是要被添加到计时器队列的。

请注意,JavaScript 语言本身没有计时器功能。它使用 Node.js 提供的计时器 API(包括 setTimeout )执行与时间相关的操作。所以计时器操作是异步的。无论是 2 秒还是 0 秒,JavaScript 都会把与时间相关的操作移交给 Node.js,然后将其完成并添加到计时器队列中。

例如:

setTimeout(function() {
        console.log('setTimeout');
    }, 0)
    console.log('yeah')


# 返回
yeah
setTimeout
로그인 후 복사

在处理异步操作时,JavaScript 会继续执行其他操作。只有在所有同步操作都已被处理完毕后,事件循环才会进入回调队列。

微任务队列(Microtask queue)

该队列分为两个队列:

. Node.js에서 제공하는 타이머 API( setTimeout 포함)를 사용하여 시간 관련 작업을 수행합니다. 따라서 타이머 작업은 비동기식입니다. 2초든 0초든 JavaScript는 시간 관련 작업을 Node.js로 전달한 다음 Node.js가 작업을 완료하고 타이머 대기열에 추가합니다.

예: 🎜
let prom = new Promise(function (resolve, reject) {
        // 延迟执行
        setTimeout(function () {
            return resolve("hello");
        }, 2000);
    });
    console.log(prom);
    // Promise { <pending> }
    
    prom.then(function (response) {
        console.log(response);
    });
    // 在 2000ms 之后,输出
    // hello
로그인 후 복사
로그인 후 복사
🎜비동기 작업을 처리하는 동안 JavaScript는 계속해서 다른 작업을 수행합니다. 모든 동기화 작업이 처리된 후에만 이벤트 루프가 콜백 대기열에 들어갑니다. 🎜

마이크로태스크 큐(Microtask queue) 🎜🎜큐는 두 개의 큐로 나뉩니다: 🎜

관련 라벨:
원천:segmentfault.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿