JavaScriptイベントループ

王林
王林オリジナル
2024-08-28 06:10:061170ブラウズ

JavaScript イベント ループとは何ですか?

JavaScript におけるイベント ループは、ノンブロッキング I/O を使用してコード、イベント、またはメッセージの実行を制御するメカニズムです。これにより、JavaScript でノンブロッキング、つまり非同期の操作を行う方法が提供されます。

主要な概念

1.シングルスレッド
JavaScript はシングルスレッドです。つまり、一度に 1 つのタスクを実行します。シングルスレッドなので、JavaScript が実行される 1 つのスレッドがいわゆる「メインスレッド」となります。

2.コールスタック
これは、JavaScript が関数呼び出しを追跡するデータ構造です。関数呼び出しはスタックにプッシュされます。戻ってくると削除されます。空の場合、JavaScript は次の処理を行う準備ができています。一般に「メインスレッド」とも呼ばれます。

3.ヒープ
これは、JavaScript がオブジェクトと変数を保存する場所です。これは動的メモリ割り当てに使用されます。

4.イベントキュー
実行を待っているメッセージまたはタスクのキュー。タスクがキューに追加されると、呼び出しスタックが空になるまで待機して実行されます。

5.イベントループ
コールスタックとイベントキューを常に監視するものです。呼び出しスタックが空の場合、タスクをイベント キューから呼び出しスタックに移動し、実行します。

JavaScript Event Loop

プロセス

  • コードの実行: JavaScript がコードの実行を開始すると、関数呼び出しがコール スタックにプッシュされます。さらに、関数を次々と実行します。
  • 非同期操作: setTimeout やネットワーク リクエストのように、操作が非同期になると、JavaScript は実行をブロックしません。代わりに、その操作を Web API、たとえばブラウザのタイマーや HTTP リクエストを処理するサービスに転送します。
  • コールバック関数: 非同期操作が完了すると、そのコールバック関数がイベント キューにプッシュされます。

  • イベント ループ チェック: イベント ループは、オーダー内のイベント キューだけでなくコール スタックもチェックするようになりました。コール スタックが空の場合、イベント キューから最初のタスクを選択し、それをコール スタックにプッシュして実行します。

console.log('Start');

setTimeout(() => {
  console.log('Timeout 1');
}, 1000);

setTimeout(() => {
  console.log('Timeout 2');
}, 500);

console.log('End');

次のことが段階的に行われることに注意してください:

  • 開始は同期操作であるため、すぐにログに記録されます。
  • 最初の setTimeout は 1000 ミリ秒の遅延で登録され、その後 Web API に送られます。そのコールバックは 1000 ミリ秒後にイベント キューに入れられます。
  • 2 番目の setTimeout は 500 ミリ秒の遅延で登録され、Web API に送信されます。そのコールバックは 500 ミリ秒後にイベント キューに入れられます。
  • 同期なので終了はすぐに記録されます。
  • 500 ミリ秒で、2 番目の setTimeout のコールバックがイベント キューからコール スタックに移動し、タイムアウト 2 を記録します。
  • setTimeout の最初のレートは、イベント キューからコール スタックまで 1000 ミリ秒で行われ、タイムアウト 1 がログに記録されます。

概要

  • コールスタック: 関数を順番に実行します。
  • イベント キュー: 実行されるメッセージまたはタスクを保存します。
  • イベント ループ: 空のイベント キューから呼び出しスタックに渡されるタスクを実行します。

以上がJavaScriptイベントループの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。