ホームページ >バックエンド開発 >C++ >`std::vector::resize()` と `boost::container::vector::resize()` は、C 標準全体で一貫したゼロ初期化動作を示しますか?

`std::vector::resize()` と `boost::container::vector::resize()` は、C 標準全体で一貫したゼロ初期化動作を示しますか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-12-04 08:45:12792ブラウズ

Does `std::vector::resize()` and `boost::container::vector::resize()` Exhibit Consistent Zero-Initialization Behavior Across C   Standards?

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。