std::list::sort() - なぜトップダウン戦略に突然切り替えたのでしょうか?
長年ボトムダウンが使用されてきたにもかかわらずstd::list::sort() の -up マージ ソート アプローチにより、Microsoft の Visual Studio 2015 は、驚くほど非効率なトップダウン マージ ソートの再帰的実装に移行しました。この変更は、根本的な動機について疑問を引き起こします。
当初、特に VS2015 でのデフォルトで構築不可能なステートフル アロケーターの導入を考慮すると、Microsoft には非効率的なアプローチに切り替えるやむを得ない理由があると考えられていました。しかし、さらなる調査の結果、元のボトムアップ マージ ソート アルゴリズムはイテレータで動作するように変更できることが判明しました。
Microsoft のトップダウン アプローチ
Microsoft のトップダウン実装では、再帰の各レベルでリストを半分に分割する再帰的アプローチ。この明らかな理由は、メモリ割り当てと例外の安全性の問題を回避するためです。並べ替えられた実行を保存するためのリストの配列を作成する代わりに、反復子を使用して元のリスト内の実行境界を追跡します。
このアプローチではメモリ割り当ての問題は回避できますが、次のような非効率性が生じます。各再帰呼び出しでリストの中間点にアクセスするため、実行時間が遅くなる可能性があります。
代替のボトムアップ アプローチ
代替案として、他の開発者はボトムアップの修正バージョンを提案しています。 -up リストの配列の代わりに反復子を使用するマージ ソート アルゴリズム。このアプローチには、各エントリが並べ替えられた実行の開始点を表す反復子の配列の作成が含まれます。リストがスキャンされると、ソートされた単一のリストが得られるまで、ノードがこれらの実行にマージされます。
この方法は、速度とメモリ効率の両方を提供し、リストでトップダウンのマージ ソートよりも約 40 ~ 50% 優れています。
結論
Microsoft がトップダウン マージ ソートに切り替えた理由は、やや不明瞭なままです。メモリ割り当てと例外の安全性に関する懸念が決定に影響を与えた可能性がありますが、これらの問題は、より高い効率を維持する別のアプローチで対処できることに留意することが重要です。効率の低いアルゴリズムを選択したということは、Microsoft がパフォーマンスよりも安定性と例外処理を優先した可能性があることを示唆しています。
以上がMicrosoft が std::list::sort() でトップダウン マージ ソートに切り替えたのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

GULCは、最小限のオーバーヘッド、積極的なインライン、およびコンパイラの最適化を優先する高性能Cライブラリです。 高周波取引や組み込みシステムなどのパフォーマンスクリティカルなアプリケーションに最適な設計では、シンプルさ、モジュールが強調されています

この記事では、c関数のリターンタイプ、基本(int、float、charなど)、派生(配列、ポインター、構造体)、およびvoid型を含む詳細を示します。 コンパイラは、関数宣言とreturnステートメントを介して返品タイプを決定し、強制します

この記事では、C関数宣言と定義、引数の合格(価値とポインターによる)、返品値、およびメモリリークやタイプの不一致などの一般的な落とし穴について説明します。 モジュール性とProviの宣言の重要性を強調しています

この記事では、文字列ケース変換のC関数について詳しく説明しています。 ctype.hのtoupper()とtolower()を使用し、文字列を介して繰り返し、ヌルターミネーターを処理することを説明しています。 ctype.hを忘れたり、文字列リテラルを変更するなどの一般的な落とし穴は

この記事では、C関数の戻り値ストレージを調べます。 通常、リターン値は通常、速度のためにレジスタに保存されます。値が大きいと、ポインターをメモリ(スタックまたはヒープ)に使用し、寿命に影響を与え、手動のメモリ管理が必要になります。直接acc

この記事では、C標準テンプレートライブラリ(STL)について説明し、そのコアコンポーネント(コンテナ、イテレーター、アルゴリズム、およびファンクター)に焦点を当てています。 これらが一般的なプログラミングを有効にし、コード効率を向上させ、読みやすさを改善する方法を詳述しています。

この記事では、形容詞の「個別」の多面的な使用法を分析し、その文法機能、一般的なフレーズ(例:「はっきりと異なる」とは異なる」、およびフォーマルと非公式の微妙なアプリケーションを調査します。

この記事では、cの効率的なSTLアルゴリズムの使用について詳しく説明しています。 データ構造の選択(ベクトル対リスト)、アルゴリズムの複雑さ分析(STD :: STD :: STD :: PARTIAL_SORTなど)、イテレーターの使用、および並列実行を強調しています。 のような一般的な落とし穴


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SublimeText3 中国語版
中国語版、とても使いやすい

ホットトピック









