非同期関数の並列実行
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 サイトの他の関連記事を参照してください。