std::inplace_vector<T,N>:: resize
From cppreference.net
<
cpp
|
container
|
inplace vector
|
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 | - | 新しい要素を初期化する値 |
| 型要件 | ||
|
-
|
||
計算量
現在のサイズと count の差に対して線形。
例外
## 翻訳のポイント - **"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]
|
現在割り当てられたストレージに保持可能な要素数を返す
(公開静的メンバ関数) |
|
コンテナが空かどうかをチェックする
(公開メンバ関数) |