ホームページ > ウェブフロントエンド > jsチュートリアル > 非同期 Promise 再試行にはどのような設計パターンが存在しますか?

非同期 Promise 再試行にはどのような設計パターンが存在しますか?

Mary-Kate Olsen
リリース: 2024-10-22 18:53:03
オリジナル
353 人が閲覧しました

Which Design Patterns Exist for Asynchronous Promise Retries?

Promise 再試行のパターンの設計

非同期プログラミングでは、失敗した Promise を解決するまで再試行すると便利なことがよくあります。 Promise でこれを実現するための 3 つの設計パターンを次に示します。

1. Promise が解決するまで再試行する (遅延と最大再試行数あり)

このパターンでは、Promise が正常に解決されるまで、各再試行の間に遅延を設けて再試行できます。 for ループを使用して .catch() ハンドラーのチェーンを作成し、続いて解決を成功させるための .then() ハンドラーを作成します。

<code class="javascript">var max = 5;
var p = Promise.reject();

for(var i=0; i<max; i++) {
    p = p.catch(attempt).catch(rejectDelay);
}
p = p.then(processResult).catch(errorHandler);</code>
ログイン後にコピー

2.結果で条件が満たされるまで再試行 (遅延なし)

このパターンでは、結果で特定の条件が満たされるまで Promise を再試行できます。前のパターンと同様の .catch() チェーン アプローチを使用しますが、rejectDelay の代わりに .then() ハンドラーを使用して結果をテストします。

<code class="javascript">var max = 5;
var p = Promise.reject();

for(var i=0; i<max; i++) {
    p = p.catch(attempt).then(test);
}
p = p.then(processResult).catch(errorHandler);</code>
ログイン後にコピー

3.結果が条件を満たすまで再試行 (遅延あり)

このパターンは前の 2 つのパターンを組み合わせたもので、条件が満たされるまで、各再試行の間に遅延を設けて Promise を再試行できます。 .catch() チェーンを使用して再試行を処理し、.then() ハンドラーを使用してテストを実行し、遅延を導入します。

<code class="javascript">var max = 5;
var p = Promise.reject();

for(var i=0; i<max; i++) {
    p = p.catch(attempt).then(test).catch(rejectDelay);
}
p = p.then(processResult).catch(errorHandler);</code>
ログイン後にコピー

これらのパターンは、Promise による再試行を処理するための簡潔で効率的な方法を提供します。障害が発生した場合でもコードが確実に実行され続けるようにします。これらは、アプリケーションの特定のニーズに合わせてカスタマイズでき、最大再試行、​​遅延間隔、再試行条件などの要素のバランスをとることができます。

以上が非同期 Promise 再試行にはどのような設計パターンが存在しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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