ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript で非同期関数を並列実行するにはどうすればよいですか?

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

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-11-24 03:35:10484ブラウズ

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 サイトの他の関連記事を参照してください。

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