> 웹 프론트엔드 > 프런트엔드 Q&A > 자바스크립트 엔진은 단일 스레드인가요?

자바스크립트 엔진은 단일 스레드인가요?

WBOY
풀어 주다: 2022-03-03 10:35:37
원래의
1678명이 탐색했습니다.

JavaScript 엔진은 단일 스레드입니다. JavaScript의 주요 목적은 사용자와 상호 작용하고 DOM을 작동하여 동시에 한 가지 작업만 수행할 수 있도록 복잡한 동기화 문제를 방지하는 것입니다. 따라서 JavaScript는 단일입니다. -스레드.

자바스크립트 엔진은 단일 스레드인가요?

이 튜토리얼의 운영 환경: Windows 10 시스템, JavaScript 버전 1.8.5, Dell G3 컴퓨터.

JavaScript 엔진은 단일 스레드인가요?

JavaScript 엔진은 단일 스레드인가요?

JS는 왜 비동기가 필요한가요? 단일 스레드는 어떻게 비동기를 구현하나요?

기술의 출현은 실제 세계의 응용 시나리오와 밀접한 관련이 있습니다.

마찬가지로 실제 시나리오를 바탕으로 질문에 답변하겠습니다

(1) JS가 싱글 스레드인 이유는 무엇인가요?

싱글 스레드: 동시에 한 가지 작업만 수행할 수 있습니다

JavaScript의 싱글 스레드 , 그리고 그 목적과 관련이 있습니다. 브라우저 스크립팅 언어인 JavaScript의 주요 목적은 사용자와 상호 작용하고 DOM을 조작하는 것입니다. 이는 단일 스레드만 가능하다는 것을 결정합니다. 그렇지 않으면 매우 복잡한 동기화 문제가 발생합니다. 예를 들어 JavaScript에 두 개의 스레드가 동시에 있다고 가정해 보겠습니다. 한 스레드는 특정 DOM 노드에 콘텐츠를 추가하고 다른 스레드는 해당 노드를 삭제합니다. 이 경우 브라우저는 어떤 스레드를 사용해야 합니까?

멀티 코어 CPU의 컴퓨팅 성능을 활용하기 위해 HTML5는 JavaScript 스크립트가 여러 스레드를 생성할 수 있도록 허용하지만 하위 스레드는 기본 스레드에 의해 완전히 제어되며 DOM을 작동해서는 안 되는 Web Worker 표준을 제안합니다. . 따라서 이 새로운 표준은 JavaScript의 단일 스레드 특성을 변경하지 않습니다.

JS는 원래 브라우저에서 사용하도록 설계되었으므로 브라우저의 JS가 멀티 스레드라고 상상해 보세요.

시나리오 설명:

이제 process1과 process2라는 2개의 프로세스가 있습니다. 다중 프로세스 JS이기 때문에 동시에 동일한 DOM에서 작동합니다.

process1은 dom을 삭제하고 process2는 dom을 편집했습니다. 동시에 브라우저는 두 가지 모순되는 명령을 어떻게 실행해야 할까요?

이렇게 생각해 보면 JS가 단일 스레드로 설계된 이유를 쉽게 이해할 수 있습니다.

(2) JS에 비동기가 필요한 이유는 무엇인가요?

시나리오 설명:

JS에 비동기가 없으면 위에서 아래로만 실행할 수 있습니다. 이전 줄의 구문 분석 시간이 매우 길다면, 그러면 다음 코드가 차단됩니다.

사용자에게 차단은 "걸림"을 의미하며 이는 사용자 경험을 저하시킵니다

그래서 JS에는 비동기 실행이 있습니다.

관련 권장 사항: javascript 학습 튜토리얼

위 내용은 자바스크립트 엔진은 단일 스레드인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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