메인 스레드는 "작업 대기열"에서 이벤트를 읽습니다. 이 프로세스는 순환적이므로 전체 작동 메커니즘을 이벤트 루프라고도 합니다. 다음 글은 Node.js의 eventloop를 익히는 데 도움이 될 것입니다.
사실 이전 글에서 브라우저의 이벤트루프에 대해서도 이야기한 적이 있습니다. 그러나 NodeJs의 이벤트루프는 브라우저의 이벤트루프와 다릅니다. eventloop를 마스터하는 것은 nodejs를 작성하는 사람들에게 매우 중요한 기술입니다. 이는 js를 작성할 수 있을 뿐만 아니라 NodeJ도 공부할 수 있다는 것을 의미하기 때문입니다.
이벤트루프가 왜 있나요?
NodeJs의 본질은 브라우저의 v8을 운영 체제에서 실행하도록 이동하여 브라우저의 이벤트 루프도 대신하는 것임을 알고 있습니다. 그런데 왜 eventloop 같은 디자인이 나타나는 걸까요?
역사적인 관점에서 볼 때, js는 페이지에서 DOM을 운영하기 위한 매우 간단한 언어로 설계되었습니다(JS가 단 10일 만에 설계되었다는 이야기는 다들 들어보셨을 거라 믿습니다). 이 목표를 위해 우리는 js의 실행이 가능한 한 간단하고 가벼워지기를 바랍니다. js만큼 가벼운 렌더링 엔진은 스레드에서 실행됩니다.
그런 다음 문제가 발생합니다. 스레드에서 js를 실행하면 코드가 선형이면 물론 문제가 없습니다. 하지만 페이지에서는 사용자 상호작용이 필요하며 이러한 상호작용은 왜, 언제 발생하는지 알 수 없습니다. js를 어떻게 처리하나요? 실행 중인 코드가 앞에 있다면 사용자가 상호 작용할 때 프로그램은 어떻게 반응해야 할까요? 사용자 상호 작용이 먼저 처리되면 원래 프로그램이 일시 중지(즉, 차단)됩니다. 이러한 종류의 차단을 피하기 위해 js는 이러한 종류의 사용자 상호 작용을 저장하기 위해 메시지 대기열을 사용하는 방법을 채택합니다. 모든 프로그램 실행이 완료된 후 메시지 대기열로 이동하여 상호 작용 이벤트를 가져온 다음 실행합니다. 이렇게 하면 차단 문제가 해결됩니다.
브라우저 이벤트 루프
우리 모두는 브라우저가 페이지를 탐색할 때 사용자에게 즉시 응답하기 위해 언제든지 사용자 상호 작용이 발생할 수 있다는 것을 알고 있습니다. Node.js는 닫히지 않고 계속 반복됩니다. 대략 다음과 같습니다:
向消息队列拿任务-->执行任务-->执行完毕--> 向消息队列拿任务--> ....
물론 이전 이벤트 루프 기사에서 다양한 비동기 작업을 분류하기 위해 실제로 이벤트 루프에서 매크로 작업과 마이크로 작업을 구분한다고 언급했습니다. 실행은 대략
向消息队列拿微任务-->执行微任务-->微任务执行完毕--> 向消息队列拿宏任务-->执行宏任务-->宏任务执行完毕-->向消息队列拿微任务-->...
NodeJs의 이벤트 루프
node의 이벤트 루프는 실제로 브라우저의 이벤트 루프와 유사하지만 nodeJ는 서로 다른 시간에 서로 다른 매크로 작업을 구별합니다. 다음은 공식 흐름도입니다.
nodeJs의 각 이벤트 루프는 6개의 특정 기간으로 나뉘며 각 기간은 지정된 매크로 작업을 사용하는 것을 볼 수 있습니다. 그런 다음 각 기간의 매크로 작업이 실행되기 전에 마이크로 작업 대기열이 먼저 실행됩니다. ㅋㅋㅋ 콜백 종료 s
다음 루프까지 실행이 지연됩니다. 반복 I/O 콜백
은 내부적으로만 사용되며 개발자는 새로운 I/O 이벤트를 검색하기 위한 | poll | ||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
check | Execution | setImmediate( )||||||||||||||||||||||||||||||
콜백 닫기 | |||||||||||||||||||||||||||||||
其实通过上述表格,我们已经很清晰知道整个事件循环机制的执行顺序了。但可能大家还会有一些疑问。下面来详细讲一下。 pending callbacks这个阶段其实是处理由于操作系统出错,导致一些本应在上次事件循环中执行的回调。例如一些TCP错误。因此这部分,开发者不能主动操作,是NodeJs的一些容错机制。 check同样的,setImmediate是nodejs特有的api,他可以立即创建一个异步宏任务。不仅如此,nodejs在事件循环中还专门设了一个check时期,在这个时期会专门执行setImmediate的回调。甚至你可以在这个时期中如果不停的产生setImmediate回调,eventloop会优先处理。 close callbacks这个时期处理关闭事件,如socket.on('close', ...) 等这样可以确保在一些通讯结束前,所有任务都完成了。 微任务在eventloop中我们先来回顾浏览器与nodejs的差异: 宏任务:
微任务:
可以看到process.nextTick是nodejs特有的微任务,不仅如此,process.nextTick()的优先级高于所有的微任务,每一次清空微任务列表的时候,都是先执行 process.nextTick() 执行差异不仅是任务类型上有差异,在执行上2个环境其实也有差异。在浏览器上执行任务的时候,每执行一个宏任务之前,需要先确保微任务队列执行完了。而在nodejs上是每个时期之前,先确保微任务队列执行完。也就是说在假如在timer时期,会先把所有setTimeout,setInterval的宏任务执行完。在执行完微任务,再进入下个时期。 注意:以上执行规则是在nodejs的v11版本之前的规则。在11版本之后nodejs的执行输出是跟浏览器一样的。 setImmediate() vs setTimeout()setImmediate() 和 setTimeout()的执行先后顺序是不一定的,就是说如果你不停地执行以下代码,每次得到的结果可能是不一样的。 setTimeout(() => { console.log('timeout'); }, 0); setImmediate(() => { console.log('immediate'); }); 其中的原因是程序对时间的处理是有误差的。在setTimeout方法中设置的时间,不一定是准确的。同时在回调触发时,也无法确认事件循环处在哪个时期,可能是timer,也可能是check。所有会有不同的结果。 总结eventloop是js运行机制里的重点内容,对于NodeJs来说,eventloop的操作空间则更大。因为它被细分为不同的时期,从而让我们可能把逻辑进一步细化。同时利用nextTick的最高优先级,可以写出在浏览器无法实现的代码。因此对于深入NodeJs的开发者来说,eventloop往往是他们考察新人对NodeJs理解的第一步。 更多node相关知识,请访问:nodejs 教程!! |
위 내용은 이 글은 Node.js의 이벤트루프를 이해하는 데 도움이 될 것입니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

JavaScript는 현대 웹 개발의 핵심 언어이며 다양성과 유연성에 널리 사용됩니다. 1) 프론트 엔드 개발 : DOM 운영 및 최신 프레임 워크 (예 : React, Vue.js, Angular)를 통해 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축합니다. 2) 서버 측 개발 : Node.js는 비 차단 I/O 모델을 사용하여 높은 동시성 및 실시간 응용 프로그램을 처리합니다. 3) 모바일 및 데스크탑 애플리케이션 개발 : 크로스 플랫폼 개발은 개발 효율을 향상시키기 위해 반응 및 전자를 통해 실현됩니다.

JavaScript의 최신 트렌드에는 Typescript의 Rise, 현대 프레임 워크 및 라이브러리의 인기 및 WebAssembly의 적용이 포함됩니다. 향후 전망은보다 강력한 유형 시스템, 서버 측 JavaScript 개발, 인공 지능 및 기계 학습의 확장, IoT 및 Edge 컴퓨팅의 잠재력을 포함합니다.

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

Python은 데이터 과학 및 기계 학습에 더 적합한 반면 JavaScript는 프론트 엔드 및 풀 스택 개발에 더 적합합니다. 1. Python은 간결한 구문 및 풍부한 라이브러리 생태계로 유명하며 데이터 분석 및 웹 개발에 적합합니다. 2. JavaScript는 프론트 엔드 개발의 핵심입니다. Node.js는 서버 측 프로그래밍을 지원하며 풀 스택 개발에 적합합니다.

JavaScript는 이미 최신 브라우저에 내장되어 있기 때문에 설치가 필요하지 않습니다. 시작하려면 텍스트 편집기와 브라우저 만 있으면됩니다. 1) 브라우저 환경에서 태그를 통해 HTML 파일을 포함하여 실행하십시오. 2) Node.js 환경에서 Node.js를 다운로드하고 설치 한 후 명령 줄을 통해 JavaScript 파일을 실행하십시오.

쿼츠 타이머를 사용하여 작업을 예약 할 때 미리 쿼츠에서 작업 알림을 보내는 방법 작업의 실행 시간은 CRON 표현식에 의해 설정됩니다. 지금...

JavaScript 프로그래밍에서 JavaScript의 프로토 타입 체인에서 함수 매개 변수를 얻는 방법 프로토 타입 체인의 기능 매개 변수를 이해하고 조작하는 방법은 일반적이고 중요한 작업입니다 ...

WeChat 애플릿 웹 뷰에서 vue.js를 사용하는 동적 스타일 변위 실패가 vue.js를 사용하는 이유를 분석합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

드림위버 CS6
시각적 웹 개발 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

뜨거운 주제



