JavaScript 작동 방식을 이해하도록 안내합니다.
이 글은 javascript에 대한 관련 지식을 제공합니다. 주로 JavaScript의 작동 원리를 소개합니다. 이 글은 이를 매우 자세하게 소개하므로 필요한 모든 사람의 학습이나 업무에 참고할 수 있습니다. 그것.
[관련 권장 사항: javascript 비디오 튜토리얼, web front-end]
JavaScript가 실행되는 방식과 작동 메커니즘을 이해하려면 우선 브라우저의 핵심을 이해해야 합니다.
브라우저 커널
이에 대해 아는 사람은 누구나 알고 있습니다. 다양한 브라우저는 다양한 커널로 구성되어 있으므로 어떤 커널이 있고 일반적으로 사용되는 브라우저에서 어떤 커널을 사용하는지:
- Gecko: Netscape 및 Mozilla Firefox 브라우저에서 초기 탐색
- Trident: Microsoft에서 개발하고 IE4~IE11 브라우저에서 사용하지만 Edge 브라우저는 Blink로 전환되었습니다.
- Webkit: KHTML, 오픈 소스를 기반으로 Apple에서 개발하고 Safari에서 사용했으며 이전에는 Google Chrome도 사용했습니다. : Google에서 개발한 Webkit의 한 가지로 현재 Google Chrome, Edge, Opera 등에서 사용됩니다.
- 소위 브라우저 커널은 브라우저의 레이아웃 엔진, 즉 브라우저 엔진을 말합니다. 엔진의 작업 실행 과정은 다음과 같습니다.
그런데 이 실행 과정에서 HTML 파싱 중에 JavaScript 태그를 발견하게 됩니다. 어떻게 해야 할까요?
물론 여기서 중지하는 대신 JavaScript 코드를 비동기적으로 로드하고 실행하는 것은 어떨까요?
그래서 브라우저는 새로운 DOM 트리를 자주 생성하는 대신 HTML로 구문 분석된 DOM과 JavaScript 작업 후 DOM을 함께 넣어 최종 DOM 트리를 생성하기를 원합니다.
그렇다면 누가 JavaScript 코드를 실행할 것인가?
답변: JavaScript 엔진
JavaScript 엔진
왜 JavaScript 엔진이 필요한가요?
실제로 우리가 작성한 JavaScript가 실행을 위해 브라우저나 노드에 전달되든 결국 CPU에 의해 실행되어야 합니다.- 그러나 CPU는 실제로 기계어인 자체 명령어 세트만 알고 있습니다. , CPU에 의해 실행되기 위해서는 ;
- 따라서 JavaScript 코드를 실행을 위한 CPU 명령으로 변환하는 데 도움이 되는 JavaScript 엔진이 필요합니다.
- 일반적인 JavaScript 엔진은 무엇입니까?
- Chakra: Microsoft에서 개발, IE 브라우저에서 사용
- JavaScriptCore: Apple에서 개발한 WebKit의 JavaScript 엔진; V8: Google에서 개발한 강력한 JavaScript 엔진은 Chrome이 여러 브라우저 중에서 돋보이도록 도와줍니다. (V8은 강력한 JavaScript 엔진입니다.)
- V8 엔진
- V8은 독립형으로 실행되거나 모든 C++ 애플리케이션에 내장될 수 있습니다.
- JavaScript 코드를 실행하는 V8 엔진의 원리:
- Parse 모듈은 JavaScript 코드를 AST(추상 구문 트리)로 변환합니다. 이는 인터프리터가 JavaScript 코드를 직접 이해하지 못하기 때문입니다.
- Ignition은 AST를 ByteCode(바이트코드)로 변환하는 인터프리터입니다
- V8 공식 Ignition Documentation: https://v8.dev/blog/ignition-interpreter
- TurboFan은 바이트코드를 CPU가 직접 실행할 수 있는 기계어 코드로 컴파일할 수 있는 컴파일러입니다.
- 함수가 다중으로 호출되는 경우; 그런 다음 핫 함수로 표시되고 TurboFan을 통해 최적화된 기계어 코드로 변환되어 코드의 실행 성능이 향상됩니다.
그러나 기계어 코드는 실제로 ByteCode로 복원됩니다. 이후에 함수가 실행되는 과정에서 타입이 변경되었습니다. (예를 들어 sum 함수는 원래 숫자 타입으로 실행되었으나 나중에 문자열 타입으로 실행되었습니다.) 이전에 최적화된 기계어 코드는 연산을 제대로 처리하지 못하여 다음과 같이 변환됩니다.
- TurboFan의 V8 공식 문서: https://v8.dev/blog/turbofan-jit
- 위는 JavaScript 코드의 실행 과정입니다
【관련 추천: javascript 비디오 튜토리얼, 웹 프론트엔드】
위 내용은 JavaScript 작동 방식을 이해하도록 안내합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

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

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











WebSocket 및 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 소개: 지속적인 기술 개발로 음성 인식 기술은 인공 지능 분야의 중요한 부분이 되었습니다. WebSocket과 JavaScript를 기반으로 한 온라인 음성 인식 시스템은 낮은 대기 시간, 실시간, 크로스 플랫폼이라는 특징을 갖고 있으며 널리 사용되는 솔루션이 되었습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법을 소개합니다.

WebSocket과 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 서론: 인터넷 기술의 급속한 발전과 함께 실시간 모니터링 시스템이 다양한 분야에서 널리 활용되고 있다. 실시간 모니터링을 구현하는 핵심 기술 중 하나는 WebSocket과 JavaScript의 조합입니다. 이 기사에서는 실시간 모니터링 시스템에서 WebSocket 및 JavaScript의 적용을 소개하고 코드 예제를 제공하며 구현 원칙을 자세히 설명합니다. 1. 웹소켓 기술

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 오늘날의 디지털 시대에는 점점 더 많은 기업과 서비스에서 온라인 예약 기능을 제공해야 합니다. 효율적인 실시간 온라인 예약 시스템을 구현하는 것이 중요합니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. WebSocket이란 무엇입니까? WebSocket은 단일 TCP 연결의 전이중 방식입니다.

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 소개: 인터넷의 대중화와 기술의 발전으로 점점 더 많은 레스토랑에서 온라인 주문 서비스를 제공하기 시작했습니다. 실시간 온라인 주문 시스템을 구현하기 위해 JavaScript 및 WebSocket 기술을 사용할 수 있습니다. WebSocket은 TCP 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

JavaScript 및 WebSocket: 효율적인 실시간 일기 예보 시스템 구축 소개: 오늘날 일기 예보의 정확성은 일상 생활과 의사 결정에 매우 중요합니다. 기술이 발전함에 따라 우리는 날씨 데이터를 실시간으로 획득함으로써 보다 정확하고 신뢰할 수 있는 일기예보를 제공할 수 있습니다. 이 기사에서는 JavaScript 및 WebSocket 기술을 사용하여 효율적인 실시간 일기 예보 시스템을 구축하는 방법을 알아봅니다. 이 문서에서는 특정 코드 예제를 통해 구현 프로세스를 보여줍니다. 우리

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용

사용법: JavaScript에서 insertBefore() 메서드는 DOM 트리에 새 노드를 삽입하는 데 사용됩니다. 이 방법에는 삽입할 새 노드와 참조 노드(즉, 새 노드가 삽입될 노드)라는 두 가지 매개 변수가 필요합니다.

JavaScript에서 HTTP 상태 코드를 얻는 방법 소개: 프런트 엔드 개발에서 우리는 종종 백엔드 인터페이스와의 상호 작용을 처리해야 하며 HTTP 상태 코드는 매우 중요한 부분입니다. HTTP 상태 코드를 이해하고 얻는 것은 인터페이스에서 반환된 데이터를 더 잘 처리하는 데 도움이 됩니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. HTTP 상태 코드란 무엇입니까? HTTP 상태 코드는 브라우저가 서버에 요청을 시작할 때 서비스가
