名前空間
変種
操作

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

From cppreference.com
 
 
 
 
template< container-compatible-range<T> R >
constexpr void append_range( R&& rg );
(C++26以降)

範囲 rg の要素のコピーを、end() の前に、逆順ではない順序で挿入します。


rg の各イテレータは、1 回だけ逆参照されます。

目次

[編集] パラメータ

rg - コンテナ互換範囲。つまり、要素が T に変換可能な input_range
型要件
-
T は、*ranges::begin(rg) から inplace_vectorEmplaceConstructible である必要があります。そうでない場合、動作は未定義です。

[編集] 戻り値

(なし)

[編集] 計算量

rg のサイズに対して線形。コンストラクタの呼び出し回数は、std::ranges::size(rg)) と正確に等しくなります。

[編集] 例外

std::ranges::size(rg) > N の場合、std::bad_alloc をスローします。コピーコンストラクタ、ムーブコンストラクタ、代入演算子、または T のムーブ代入演算子、あるいは任意の InputIterator 操作によってスローされる例外以外の場合、効果はありません。それ以外の場合、例外がスローされた場合、size() >= n となり、範囲 [0n) の要素は変更されません。ここで、n はこの呼び出し前の size() の値です。

[編集]

#include <cassert>
#include <inplace_vector>
#include <iostream>
 
int main()
{
    using I = std::inplace_vector<int, 8>;
    auto head = I{1, 2, 3, 4};
    const auto tail = {-5, -6, -7};
    head.append_range(tail);
    assert(head.size() == 7 and (head == I{1, 2, 3, 4, -5, -6, -7}));
    try
    {
        head.append_range(tail); // throws: no space
    }
    catch(const std::bad_alloc&)
    {
        std::cout << "std::bad_alloc\n";
    }
}

出力

std::bad_alloc

[編集] 関連項目

末尾に要素の範囲を追加しようと試みる
(public member function)
要素の範囲を挿入する
(public member function)
末尾に要素を追加する
(public member function)
末尾に要素を直接構築する
(public member function)
English 日本語 中文(简体) 中文(繁體)