Javascript 실행 메커니즘 HTML5 이전에는 브라우저에서 JavaScript 실행이 단일 스레드 방식으로 작동했지만 멀티 스레딩을 시뮬레이션하는 방법은 여러 가지가 있습니다(예: Javascript의 setinterval 메서드, setTimeout 메서드) 등) 그러나 본질적으로 프로그램 실행은 여전히 단일 스레드 예약 방식으로 JavaScript 엔진에 의해 수행됩니다. HTML5에 도입된 작업자 스레드를 사용하면 브라우저 측 Javascript 엔진이 Javascript 코드를 동시에 실행할 수 있으므로 브라우저 측 다중 스레드 프로그래밍을 효과적으로 지원할 수 있습니다.
Javascript의 다중 스레드 - WebWorker
HTML5의 Web Worker는 두 가지 스레드 유형으로 나눌 수 있습니다. 하나는 전용 스레드 Dedicated Worker이고 다른 하나는 공유 스레드입니다. 노동자. 두 유형의 스레드 모두 서로 다른 용도로 사용됩니다.
전용 웹 워커 전용 워커는 자신을 생성한 스크립트에 연결되어 다른 워커나 브라우저 구성 요소와 통신할 수 있지만 DOM과는 통신할 수 없습니다. 내 생각에 전용의 의미는 이 스레드가 한 번에 하나의 요구 사항만 처리한다는 것입니다. IE를 제외한 다양한 주류 브라우저에는 전용 스레드가 구현되어 있어 안심하고 사용할 수 있습니다.
스레드 생성 워커 생성은 매우 간단합니다. 스레드에서 실행해야 하는 JavaScript 파일의 파일 이름을 생성자에 전달하기만 하면 됩니다.
스레드 통신 메인 스레드와 하위 스레드 간의 통신을 위해 스레드 객체의 postMessage 및 onmessage 메소드가 사용됩니다. 누가 누구에게 데이터를 보내든 송신자는 postMessage 메소드를 사용하고, 수신자는 onmessage 메소드를 사용하여 데이터를 수신합니다. postMessage에는 전송되는 데이터인 하나의 매개변수만 있고, onmessage에도 하나의 매개변수만 있습니다. 이벤트인 경우에는 event.data를 통해 수신된 데이터를 가져옵니다.
JSON 데이터 보내기 JSON은 JS에서 기본적으로 지원하는 기능이므로 JSON을 사용하여 복잡한 데이터를 전송할 필요가 없습니다. 예:
postMessage({ 'cmd': 'init', 'timestamp': Date.now()});
오류 처리 스레드에서 오류가 발생하면 onerror 이벤트 콜백이 호출됩니다. 따라서 오류를 처리하는 방법은 매우 간단합니다. 즉, 스레드 인스턴스의 onerror 이벤트를 연결하는 것입니다. 이 콜백 함수에는 3개의 필드가 있는 error 매개변수가 있습니다. message - 오류 메시지, filename - 오류가 발생한 스크립트 파일 lineno - 오류가 발생한 줄.
스레드 소멸 스레드 내부에서는 close 메소드를 사용하여 자신을 소멸시킵니다. 스레드 외부의 메인 스레드에서는 스레드 인스턴스의 종료 메소드를 사용하여 스레드를 소멸시킵니다.
예를 통해 스레드의 기본 작업을 살펴보겠습니다.
HTML 코드:
웹 작업자 fibonacci
fibonacci.js 코드:
코드 복사
코드는 다음과 같습니다.postMessage(fibonacci(n))
}; 동일한 디렉터리에 들어가서 File 페이지를 실행하고 콘솔을 확인하면 작업 결과를 볼 수 있습니다.
한 가지 더 중요한 점은 메인 스레드에서 onmessage 이벤트를 다른 방식으로 연결할 수 있다는 것입니다.
코드 복사
코드는 다음과 같습니다.
worker.addEventListener('message', function(event) {
console.log("Result:" event.data);