序文: js はシングルスレッド言語なので、非同期にすることは不可能です。しかし、js のホスト環境 (ブラウザ、ノードなど) はマルチスレッドです。ホスト環境によって、js は何らかの方法で非同期特性 (イベント駆動) を持ちます。 js では、一般的にすべてのタスクを 2 つのカテゴリに分類します。1 つは同期タスク、もう 1 つは非同期タスクです。非同期タスクには、マイクロタスクとマクロタスクというさらに詳細な分類があります。 1. コンセプト1.1 マクロタスクマクロタスク ---- JS 内部タスクと 1.2 マイクロタスクマイクロタスク ---- マイクロタスクは通常、一連のアクションに関するフィードバックの提供など、現在の同期タスクが完了した直後に実行する必要があるタスク、または新しいタスクを割り当てずに非同期で実行する必要があるタスクであり、パフォーマンスのオーバーヘッドを削減できます。 2. 実行順序まずコードの一部を見て、実行順序について説明しましょう。 コンソール.log(1) タイムアウトを設定する(() => { コンソール.log(2) }) Promise.resolve().then(() => { コンソール.log(3) }) コンソール.log(4) 上記のコードによって出力される結果は 1 4 3 2 です。上記のコードから、実行順序は次のようになることがわかります。 最初に同期コードを実行します。非同期マクロタスクに遭遇すると、非同期マクロタスクをマクロタスクキューに入れます。非同期マイクロタスクに遭遇すると、非同期マイクロタスクをマイクロタスクリストに入れます。すべての同期コードが実行されると、非同期マイクロタスクをリストからメインスレッドに転送して実行します。非同期マイクロタスクの実行後、非同期マクロタスクをキューからメインスレッドに転送して実行します。すべてのタスクが実行されるまで、このサイクルが継続されます。
3. タスク関係マクロタスクが主流です。js 各マクロタスクの後にはマイクロタスク キューが続きます。マイクロタスク キューに命令またはメソッドがある場合は、それらが最初に実行されます。そうでない場合は、すべてのマクロ タスクが完了するまで、次のマクロ タスクの実行を開始します。 4. タスクの詳細マクロタスクの後にもマイクロタスクが存在するのはなぜですか?これは、マクロタスクがパフォーマンスをあまりにも多く消費するためです。以前に準備されたいくつかのメソッドが必要で最後に実行され、新しいマクロタスクを追加したくない場合は、これらのメソッドを 1 つずつマイクロタスク キューに入れることができます。このマクロタスク内のコードが実行されると、マイクロタスク キューが実行されます。 したがって、現在の同期コードが実行され、非同期タスクに遭遇した場合、それが非同期マクロタスクであれば、次のラウンドのマクロタスクキューに配置され、非同期マイクロタスクであれば、マイクロタスクキューに配置され、現在のマクロタスクに続きます。マイクロタスクは、マクロタスクの小さな末尾に相当します。したがって、現在のマクロタスクが実行されると、その後ろで待機している非同期マイクロタスクは、継続実行のためにすぐにキューに入れられます。非同期マクロタスクは次のラウンドまで待機する必要があるため、非同期マイクロタスクがマクロタスクの前に実行されます。 以下もご興味があるかもしれません:
|
目次1. forループ: 基本的でシンプル2. forEach() メソッド: コールバック関数の使...
nohup コマンド: プロセスを実行しており、アカウントからログアウトしてもプロセスが終了しないと...
目次1. レシピ集1.1 プロジェクトの背景1.2 テクノロジースタック1.3 開発環境1.4. プ...
今日は、JavaScript を使用して Web ページ上にプレーヤーを作成する方法を紹介します。誰...
【歴史的背景】私は 3 年間 MySQL-DBA として働いてきましたが、MySQL が「基本的に利...
目次コンテナデータボリュームとはコンテナ データ ボリュームが必要なのはなぜですか?使用データボリュ...
目次概要サブクエリサブクエリの分類クエリの結果によるとサブクエリの位置で区別する選択後のサブクエリサ...
1. Docker Composeの概要Compose は、マルチコンテナ Docker アプリケー...
目次1. ビューフック1. ngAfterViewInit および ngAfterViewCheck...
場合によっては、SQL へのデータのエクスポートとインポートを容易にするために、特定のツールを使用し...
最近、Zoom ビデオ会議をテストし、100 人が同時に会議に参加することをシミュレートする必要があ...
場合によっては、ページにプロンプト ボックスやバブル ボックスが必要になることがあります。CSS...
データベーストランザクション分離レベルデータベース トランザクションには、低から高まで 4 つの分離...
まず、このブログのケースデモンストレーション テーブルを作成します。 create table a(...
目次序文スタイル機能説明初期化コードイベントリスナーの追加リスナーツールバーモニターテーブル行ツール...