名前空間
変種
操作

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

From cppreference.com
 
 
 
 
template< container-compatible-range<T> R >
constexpr std::ranges::borrowed_iterator_t<R> try_append_range( R&& rg );
(C++26以降)

rg の先頭要素を、すべての要素が挿入されるか、または内部ストレージが使い尽くされる(すなわち、size() == capacity()true になる)まで、end() の前にコピーして追加します。

すべてのイテレータと参照は有効なままです。end() イテレータは無効になります。

rg 内の各イテレータは、最大で1回逆参照されます。

目次

[編集] パラメータ

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

[編集] 戻り値

rg の要素のうち、*this に挿入されなかった最初の要素を指すイテレータ。そのような要素が存在しない場合は、ranges::end(rg)

[編集] 計算量

挿入された要素数に線形。

[編集] 例外

挿入された要素の初期化によってスローされる可能性のある例外。

inplace_vector は、*基本的な例外安全性保証* を提供します。すなわち、呼び出し前のコンテナのすべての要素は保持され、すでに挿入されたすべての要素(例外発生前に挿入されたもの)も保持されます。

[編集] 注記

[編集]

#include <cassert>
#include <initializer_list>
#include <inplace_vector>
 
int main()
{
    using I = std::inplace_vector<int, 8>;
    auto nums = I{1, 2, 3};
    const auto rg = {-1, -2, -3};
 
    auto it = nums.try_append_range(rg);
    assert(nums.size() == 6);
    assert((nums == I{1, 2, 3, -1, -2, -3}));
    assert(it == rg.end());
 
    it = nums.try_append_range(rg);
    assert(nums.size() == 8);
    assert((nums == I{1, 2, 3, -1, -2, -3, -1, -2}));
    assert(it == rg.begin() + 2);
}

[編集] 関連項目

末尾に要素の範囲を追加する
(公開メンバ関数) [編集]
末尾に要素を追加する
(公開メンバ関数) [編集]
末尾に要素を追加しようと試みる
(public member function) [編集]
末尾に要素を無条件で追加する
(public member function) [編集]
末尾に要素を直接構築する
(公開メンバ関数) [編集]
末尾に要素を直接構築しようと試みる
(public member function) [編集]
末尾に要素を無条件で直接構築する
(public member function) [編集]
最後の要素を削除する
(公開メンバ関数) [編集]
引数から推論された型の std::back_insert_iterator を作成する
(関数テンプレート) [編集]
English 日本語 中文(简体) 中文(繁體)