Vector::resize() の動作は C 11 および Boost.Container で一貫していますか?
std::vector:: の動作size() は通常、データを一時的にバッファリングし、使用前に適切なサイズに変更するために使用されます。 C 03 では、std::vector::resize() はコピーすることで新しい要素を作成しましたが、C 11 では、コピーせずに新しい要素を初期化するオーバーロードが導入されました。
Boost.Container は、boost:: に追加のdefault_init オーバーロードを提供します。 container::vector::resize()、新しい要素をデフォルト値で初期化します。この機能は、必要なものに対してのみ料金を支払うという C 11 の設計哲学と一致しています。
C 03 と C 11 の両方のモードで std::vector と boost::container::vector の動作をテストすると、予期しない結果が発生します。が観察されました。 C 03 と C 11 の両方で、初期化を指定せずにベクターのサイズを変更すると、std::vector と boost::container::vector の両方で新しい要素の初期化がゼロになります。
この動作は、インターフェイスが変更されたことを示しています。 in std::vector は実装には影響せず、resize() で追加された最終要素は依然としてゼロで初期化されます。問題は、この動作が正しいかどうかです。
以上が`std::vector::resize()` と `boost::container::vector::resize()` は、C 標準全体で一貫したゼロ初期化動作を示しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。