JavaScript で非同期関数を並列実行するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-11-24 03:35:10
オリジナル
383 人が閲覧しました

How Can I Execute Async Functions in Parallel in JavaScript?

非同期関数の並列実行

ES7/ES2016 では、await 式の順次実行がデフォルトの動作であり、 で Promise を連鎖するのと似ています。それから()。ただし、非同期呼び出しを並行して実行するには、別のアプローチがあります。

Promise.all() による並列実行

1 つの優れた解決策は、Promise.all() を使用することです。 )。このメソッドは、Promise の配列を受け取り、結果の配列に解決される単一の Promise を返します:

await Promise.all([someCall(), anotherCall()]);
ログイン後にコピー

個々の結果を格納するには、戻り値を変数に分解できます:

let [someResult, anotherResult] = await Promise.all([someCall(), anotherCall()]);
ログイン後にコピー

警告: catch() で拒否を処理します

次のことに注意してくださいPromise.all() は「フェイルファスト」セマンティクスを実装します。これは、入力 Promise のいずれかが拒否された場合、操作全体が失敗した Promise からのエラーで拒否されることを意味します。潜在的なエラーをキャッチして処理するには、.catch() メソッドを使用します。

例:

Promise.all([happy('happy', 100), sad('sad', 50)])
  .then(console.log).catch(console.log); // Logs 'sad'
ログイン後にコピー

以上がJavaScript で非同期関数を並列実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート