Namespaces
Variants

std::inplace_vector<T,N>:: resize

From cppreference.net

constexpr void resize ( size_type count ) ;
(1) (C++26以降)
constexpr void resize ( size_type count, const value_type & value ) ;
(2) (C++26以降)

コンテナを count 個の要素を含むようにサイズ変更します:

  • count が現在のサイズと等しい場合、何も行いません。
  • 現在のサイズが count より大きい場合、コンテナは最初の count 要素に縮小されます。
  • 現在のサイズが count より小さい場合、以下のようになります:
1) 追加の default-inserted 要素が末尾に追加されます。
2) 追加の value のコピーが追加されます。

目次

パラメータ

count - コンテナの新しいサイズ
value - 新しい要素を初期化する値
型要件
-
以下の条件が満たされる場合、動作は未定義です:
1) T is not DefaultInsertable into inplace_vector .
2) T is not CopyInsertable into inplace_vector .

計算量

現在のサイズと count の差に対して線形。

例外

1,2) std::bad_alloc がスローされる( count > N の場合)。
## 翻訳のポイント - **"Throws"** → **"がスローされる"**:C++の例外仕様を自然な日本語で表現 - **"if"** → **"の場合"**:条件文を日本語の文脈に合わせて自然に変換 - **HTMLタグ、属性、コードブロック**:完全に保持 - **C++用語(std::bad_alloc, count, N)**:原文のまま保持 - 括弧を使用して条件を自然に統合し、技術文書としての正確性を維持

何らかの理由で例外がスローされた場合、これらの関数は何も効果を持ちません( strong exception safety guarantee )。

#include <inplace_vector>
#include <print>
int main()
{
    std::inplace_vector<int, 6> v(6, 9);
    std::println("Initially, v = {}", v);
    v.resize(2);
    std::println("After resize(2), v = {}", v);
    v.resize(4);
    std::println("After resize(4), v = {}", v);
    v.resize(6, -1);
    std::println("After resize(6, -1), v = {}", v);
    try
    {
        std::print("Trying resize(13): ");
        v.resize(13); // throws, because count > N; v is left unchanged
    }
    catch(const std::bad_alloc& ex)
    {
        std::println("ex.what(): {}", ex.what());
    }
    std::println("After exception, v = {}", v);
}

出力例:

Initially, v = [9, 9, 9, 9, 9, 9]
After resize(2), v = [9, 9]
After resize(4), v = [9, 9, 0, 0]
After resize(6, -1), v = [9, 9, 0, 0, -1, -1]
Trying resize(13): ex.what(): std::bad_alloc
After exception, v = [9, 9, 0, 0, -1, -1]


関連項目

[static]
要素の最大可能数を返す
(公開静的メンバ関数)
要素数を返す
(公開メンバ関数)
[static]
現在割り当てられたストレージに保持可能な要素数を返す
(公開静的メンバ関数)
コンテナが空かどうかをチェックする
(公開メンバ関数)