一般に、同時実行アルゴリズムは逐次アルゴリズムよりも高速であると考えられています。ただし、指定されたコードでは、エラトステネスのふるいアルゴリズムの同時バージョンは逐次バージョンよりも遅くなります。この記事では、この予期しない結果の背後にある理由を調査し、提供されたコードの潜在的な問題を強調し、順次実装と同時実装の両方のパフォーマンスを向上させるためのいくつかの最適化を提案します。
PrimesSeq クラスは、エラトステネスのふるいアルゴリズムの逐次バージョンを実装します。バイト配列 bitArr を使用してふるいを表します。配列内の各ビットは数値を表し、ビットが設定されている場合、その数値は非素数としてマークされます。このアルゴリズムは、2 から開始してふるいを繰り返し、現在の数値のすべての倍数を非素数としてマークします。 isPrime 関数は、ふるい内の対応するビットが設定されていないかをチェックすることで、数値が素数であるかどうかをチェックします。 printAllPrimes 関数は、アルゴリズムによって検出されたすべての素数を出力します。
PrimesPara クラスは、エラトステネスのふるいアルゴリズムの同時バージョンを実装します。ふるいを複数のチャンクに分割し、各チャンクを別個のスレッドに割り当てます。各スレッドは、それに割り当てられた数値の倍数を非素数としてマークする責任があります。メインスレッドは、初期プライムの生成とスレッドの開始を担当します。 crossOut 関数は、数値を非素数としてマークするために使用されます。 generateErastothenesConcurrently 関数は素数を同時に生成します。
指定されたコードでは、アルゴリズムの同時バージョンは逐次バージョンよりも約 10 倍遅くなります。通常、同時アルゴリズムは逐次アルゴリズムより高速であるため、これは予想外です。
提供されたコードには潜在的なボトルネックがいくつかあります。
順次実装と同時実装の両方に適用できる最適化がいくつかあります。
一般に、同時アルゴリズムは順次アルゴリズムよりも高速です。場合によっては、逐次アルゴリズムの方が高速である可能性があります。エラトステネスの篩アルゴリズムの場合、スレッドの作成と同期、フォールス シェアリング、負荷の不均衡のオーバーヘッドが同時実行のメリットを上回る可能性があります。
この記事で説明する最適化を適用することで、次のことが可能になります。エラトステネスのふるいアルゴリズムの逐次実装と同時実装の両方のパフォーマンスを向上させます。
以上がエラトステネスの同時ふるいアルゴリズムが逐次バージョンより遅いのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。