序文ご存知のとおり、JavaScript は本質的にシングルスレッドですが、ブラウザは非同期リクエストを非常にうまく処理できます。なぜでしょうか?この背後にある原理は、イベント ループ メカニズムと大きく関係しています。 イベントループを調べる前に、ブラウザ実行スレッドを理解する必要があります~~ ブラウザのレンダリング プロセスはマルチスレッドです。ブラウザ内の各タブは独立したプロセスを表します。ブラウザ カーネルはブラウザのマルチプロセスの 1 つであり、主にページのレンダリング、スクリプトの実行、イベント処理などを担当します。含まれるスレッドは次のとおりです
ブラウザのレンダリングプロセスを理解した後は、JS の動作メカニズムも理解する必要があります。 JSの動作メカニズムはイベントループです 実行スタックJS が実行される環境はホスト環境と呼ばれます。 実行スタック: コール スタックは、さまざまな関数の実行環境を格納するために使用されるデータ構造です。各関数が実行される前に、その関連情報が実行スタックに追加されます。関数が呼び出される前に実行環境が作成され、実行スタックに追加されます。関数が呼び出された後、実行環境は破棄されます。 イベントループjs のすべてのタスクは、同期タスクと非同期タスクに分けられます。同期タスクは、すぐに実行されるタスクです。同期タスクは通常、実行のためにメインスレッドに直接入ります。一方、非同期タスクは、Ajax ネットワーク リクエスト、setTimeout タイミング関数など、すべて非同期タスクである非同期で実行されるタスクです。非同期タスクは、タスク キュー (先入れ先出し) メカニズムを通じて調整されます。同期タスクと非同期タスクはそれぞれ異なる実行環境に入ります。同期タスクはメインスレッド、つまりメイン実行スタックに入り、非同期タスクはタスクキューに入ります。メイン スレッド内のタスクが完了して空になると、タスク キューが読み取られ、対応するタスクが読み取られ、実行のためにメイン スレッドにプッシュされます。 この一定の繰り返しをイベント ループと呼びます。具体的なプロセスは以下の図の通りです。 イベント ループでは、各ループ操作はティックと呼ばれます。各ティック タスク キーの手順は、次のようにまとめることができます。1. マクロ タスクを実行します (スタックにマクロ タスクがない場合は、イベント キューから取得します)。2. 実行中にマイクロ タスクに遭遇した場合は、マイクロ タスクのタスク キューに追加します。3. マクロ タスクの実行後、現在のマイクロ タスク キュー内のすべてのマイクロ タスクが直ちに実行されます (順番に)。4. 現在のマクロ タスクの実行後、レンダリングのチェックを開始し、その後 GUI スレッドがレンダリングを引き継ぎます。5. レンダリングが完了したら、JS スレッドが引き続き引き継いで次のマクロ タスクを開始します (イベント キューから取得します)。 マクロタスクには主に、スクリプト(コード全体)、setTimeout、setInterval、I/O、UIインタラクションイベント、setImmediate(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 をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: MySQL テーブルの読み取り、書き込み、インデックス作成、その他の操作の SQL ステートメントの効率最適化の問題を分析します。
最も一般的に使用されるレイアウト要素として、DIV は Web 開発において重要な役割を果たします。...
まず、いくつかの概念を明確にします。 JDBC: Javaデータベース接続、Oricalによって規定...
1. Navicat for MySQL 15をダウンロードするhttps://www.navica...
目次序文フィルターとは何かフィルターの使い方グローバルフィルターローカルフィルターフィルターは直列に...
1. はじめに:友人はシステム知識を学びたいと考えており、Apple のラップトップを使用していまし...
問題の説明1. 収集ステーションのデータベース2. データが無い状態での移動は問題ありませんが、デー...
主な違いは次のとおりです。 1. MySQL はデフォルトで MyISAM を使用します。 2. M...
目次序文1. イントラネットDNS AレコードとMXレコードを構成する2. メールサーバの初期化設定...
注記記事表示リストインターフェースを開発する場合、情報の基本的な概要を提供するために記事ヘッダーコン...
構造とプレゼンテーションを分離するもう 1 つの重要な側面は、セマンティック マークアップを使用して...
:not疑似クラスセレクターは、式に一致しない要素をフィルタリングできます。例 テーブル tbod...
昨日、VMware に CentOS7 をインストールしました。Tomcat パッケージを転送するた...
CSSを使用してスクロールバーを変更する1.コンテンツがオーバーフローした場合のオーバーフロー設定水...
最近、Grover の Web サイトで楽しいホバー アニメーションを見つけ、自分自身のインスピレー...
ウェブサイトがワイドスクリーンの場合、ブラウザ ウィンドウを左右にドラッグすると、ウェブサイトの幅が...