最初のベンチマークではそうではないことが示されているにもかかわらず、std::vector の反復が std::array の反復よりも速いのはなぜですか?

Susan Sarandon
リリース: 2024-11-01 15:35:02
オリジナル
256 人が閲覧しました

Why is std::vector iteration faster than std::array iteration despite initial benchmarks suggesting otherwise?

なぜ std::vector 反復が std::array 反復を上回るのか

当初の結論の誤解

当初は欠陥のあるベンチマークstd::array の反復のほうがstd::vector の反復。ただし、ベンチマークを修正すると、std::vector の方が大幅に高速であることが判明しました。

ベンチマークの実装

精度を確保するために、ベンチマークでは次のようないくつかの改善が行われました。

  • ループを防ぐための結果の利用最適化
  • -O3 速度向上のための最適化フラグ
  • 静的変数の干渉のない孤立ループ測定用の std::chrono

結果と説明

ベンチマークの結果から、std::vector の反復が 1 秒以内に完了したことがわかりました。 std::array の反復には約 99 ミリ秒かかりましたが、

この不一致はメモリ ページの動作に起因します。ベンチマークでは、std::array は実行可能ファイルの .bss セクションにあったため (ゼロ初期化)、そのメモリ ページはプロセス アドレス空間にロードされませんでした。逆に、std::vector が割り当てられ、ゼロが埋め込まれていたため、ページが存在していました。

解決策

std::array のページをゼロで事前にフォールトする-filling または Linux で mlock() を使用すると、そのページがアドレス空間に取り込まれ、その反復速度はstd::vector.

以上が最初のベンチマークではそうではないことが示されているにもかかわらず、std::vector の反復が std::array の反復よりも速いのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!