jsのイベントループ機構の解析

jsのイベントループ機構の解析

序文

ご存知のとおり、JavaScript は本質的にシングルスレッドですが、ブラウザは非同期リクエストを非常にうまく処理できます。なぜでしょうか?この背後にある原理は、イベント ループ メカニズムと大きく関係しています。

イベントループを調べる前に、ブラウザ実行スレッドを理解する必要があります~~

ブラウザのレンダリング プロセスはマルチスレッドです。ブラウザ内の各タブは独立したプロセスを表します。ブラウザ カーネルはブラウザのマルチプロセスの 1 つであり、主にページのレンダリング、スクリプトの実行、イベント処理などを担当します。含まれるスレッドは次のとおりです

GUI レンダリング スレッド: ページのレンダリング、HTML および CSS の解析を行って DOM ツリーを形成します。
JS エンジン スレッド: コード、ユーザー入力、ネットワーク要求を解釈して実行します。
イベント処理スレッド: クリック、マウス、その他のインタラクティブなイベントが発生すると、イベント関数がキューに入れられます。
タイマーがスレッドをトリガーします。時間切れになると、実行関数がタスク キューにプッシュされます。
http ネットワーク リクエスト スレッド: ユーザーの get リクエストと post リクエストを処理し、返された結果をタスク キューにプッシュします。

ブラウザのレンダリングプロセスを理解した後は、JS の動作メカニズムも理解する必要があります。 JSの動作メカニズムはイベントループです

実行スタック

JS が実行される環境はホスト環境と呼ばれます。

実行スタック: コール スタックは、さまざまな関数の実行環境を格納するために使用されるデータ構造です。各関数が実行される前に、その関連情報が実行スタックに追加されます。関数が呼び出される前に実行環境が作成され、実行スタックに追加されます。関数が呼び出された後、実行環境は破棄されます。

イベントループ

js のすべてのタスクは、同期タスクと非同期タスクに分けられます。同期タスクは、すぐに実行されるタスクです。同期タスクは通常、実行のためにメインスレッドに直接入ります。一方、非同期タスクは、Ajax ネットワーク リクエスト、setTimeout タイミング関数など、すべて非同期タスクである非同期で実行されるタスクです。非同期タスクは、タスク キュー (先入れ先出し) メカニズムを通じて調整されます。同期タスクと非同期タスクはそれぞれ異なる実行環境に入ります。同期タスクはメインスレッド、つまりメイン実行スタックに入り、非同期タスクはタスクキューに入ります。メイン スレッド内のタスクが完了して空になると、タスク キューが読み取られ、対応するタスクが読み取られ、実行のためにメイン スレッドにプッシュされます。 この一定の繰り返しをイベント ループと呼びます。具体的なプロセスは以下の図の通りです。

イベント ループでは、各ループ操作はティックと呼ばれます。各ティック タスク キーの手順は、次のようにまとめることができます。1. マクロ タスクを実行します (スタックにマクロ タスクがない場合は、イベント キューから取得します)。2. 実行中にマイクロ タスクに遭遇した場合は、マイクロ タスクのタスク キューに追加します。3. マクロ タスクの実行後、現在のマイクロ タスク キュー内のすべてのマイクロ タスクが直ちに実行されます (順番に)。4. 現在のマクロ タスクの実行後、レンダリングのチェックを開始し、その後 GUI スレッドがレンダリングを引き継ぎます。5. レンダリングが完了したら、JS スレッドが引き続き引き継いで次のマクロ タスクを開始します (イベント キューから取得します)。

マクロタスクには主に、スクリプト(コード全体)、setTimeout、setInterval、I/O、UIインタラクションイベント、setImmediate(Node.js環境)が含まれます。
マイクロタスクには主に、Promise、MutaionObserver、process.nextTick(Node.js 環境)が含まれます。

イベントループの例

console.log('スクリプトの開始');
//スクリプト全体が最初のマクロタスクとしてメインスレッドに入り、console.logに遭遇し、スクリプト開始を出力します。
setTimeout(関数() {
  コンソールログに'setTimeout'と入力します。
}, 0);
//setTimeoutに遭遇すると、そのコールバック関数がマクロタスクイベントキューに配布されます Promise.resolve().then(function() {
  コンソールにログ出力します。
}).then(関数() {
  コンソールにログ出力します。
});
// Promise に遭遇すると、その then 関数がマイクロタスク イベント キューに割り当てられ、then1 として記録されます。次に、別の then 関数に遭遇し、マイクロタスク イベント キューに割り当てられ、then2 として記録されます。
console.log('スクリプト終了');
//console.logに遭遇したら、出力スクリプト終了

このように、イベント キューには、マクロ タスク: setTimeout、マイクロ タスク: then1、then2 の 3 つのタスクがあります。まずマイクロタスクthen1を実行し、promise1を出力し、次にthen2を実行し、promise2を出力して、すべてのマイクロタスクをクリアします。

setTimeoutタスクを実行し、setTimeoutを出力します。これまでの出力順序は、スクリプト開始、スクリプト終了、promise1、promise2、setTimeoutです。

要約:

JavaScript はシングルスレッド言語です。非同期操作はイベント ループ キューに配置され、メイン実行スタックの実行を待機します。専用の非同期実行スレッドはありません。

js のイベントループの仕組みについての記事はこれで終わりです。より関連性の高い js イベントループのコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き閲覧してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • JSのイベントループの仕組みを説明する記事
  • JavaScriptのイベントループの仕組みについて簡単に説明します
  • JavaScriptのイベントループの仕組みの分析
  • JSブラウザイベントループの仕組みの詳しい説明
  • JavaScriptイベントループの仕組みの詳しい説明
  • js イベントループメカニズムの分析例
  • JS のイベントループメカニズムの詳細な例

<<:  MySQL テーブルの読み取り、書き込み、インデックス作成、その他の操作の SQL ステートメントの効率最適化の問題を分析します。

>>:  CentOS8 ネットワークカード設定ファイル

推薦する

DIV の一般的なタスク (パート 1) — 一般的なタスク (スクロール バーの表示、div の非表示、イベント バブリングの無効化など)

最も一般的に使用されるレイアウト要素として、DIV は Web 開発において重要な役割を果たします。...

JDBC を使用して Mysql データベースに接続する際に発生する可能性のある問題の概要

まず、いくつかの概念を明確にします。 JDBC: Javaデータベース接続、Oricalによって規定...

Navicat for MySQL 15 登録とアクティベーションの詳細なチュートリアル

1. Navicat for MySQL 15をダウンロードするhttps://www.navica...

Vueのフィルターについて知っておくべきこと

目次序文フィルターとは何かフィルターの使い方グローバルフィルターローカルフィルターフィルターは直列に...

VMWare12 グラフィックチュートリアルで Apple Mac OS X をインストールする

1. はじめに:友人はシステム知識を学びたいと考えており、Apple のラップトップを使用していまし...

mysql エラー 1033 を解決する方法: ファイル内の情報が正しくありません: 'xxx.frm'

問題の説明1. 収集ステーションのデータベース2. データが無い状態での移動は問題ありませんが、デー...

MyISAMとInnoDBの違いについてお話しましょう

主な違いは次のとおりです。 1. MySQL はデフォルトで MyISAM を使用します。 2. M...

Centos7.9 で独立したメール サーバーを構築するための詳細な手順

目次序文1. イントラネットDNS AレコードとMXレコードを構成する2. メールサーバの初期化設定...

クリックして展開し、全文を読む機能を実現する純粋なCSS

注記記事表示リストインターフェースを開発する場合、情報の基本的な概要を提供するために記事ヘッダーコン...

セマンティックウェブページ XHTML セマンティックマークアップ

構造とプレゼンテーションを分離するもう 1 つの重要な側面は、セマンティック マークアップを使用して...

CSSの複数条件の書き方の詳細説明:

:not疑似クラスセレクターは、式に一致しない要素をフィルタリングできます。例 テーブル tbod...

VMwareでCentOSがインターネットにアクセスできない問題を素早く解決

昨日、VMware に CentOS7 をインストールしました。Tomcat パッケージを転送するた...

HTMLタグオーバーフロー処理アプリケーション

CSSを使用してスクロールバーを変更する1.コンテンツがオーバーフローした場合のオーバーフロー設定水...

CSS変数を使用して、クールで素晴らしいフローティング効果を実現します。

最近、Grover の Web サイトで楽しいホバー アニメーションを見つけ、自分自身のインスピレー...

IE6のmin-widthとmin-heightと互換性を持たせる簡単な方法

ウェブサイトがワイドスクリーンの場合、ブラウザ ウィンドウを左右にドラッグすると、ウェブサイトの幅が...