名前空間
変種
操作

std::deque<T,Allocator>::append_range

From cppreference.com
< cpp‎ | コンテナ‎ | deque
 
 
 
 
template< container-compatible-range<T> R >
void append_range( R&& rg );
(C++23から)

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

すべてのイテレータ(end() イテレータを含む)は無効になります。参照は無効になりません。

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

目次

[編集] パラメータ

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

[編集] 戻り値

(なし)

[編集] 計算量

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

[編集] 例外

コピーコンストラクタ、ムーブコンストラクタ、代入演算子、または `T` のムーブ代入演算子以外で例外がスローされた場合、効果はありません。どちらかの端に単一の要素を挿入中に例外がスローされた場合、効果はありません。それ以外の場合、非 CopyInsertable な `T` のムーブコンストラクタによって例外がスローされた場合、効果は未指定です。

注釈

機能テストマクロ 規格 機能
__cpp_lib_containers_ranges 202202L (C++23) ranges対応の構築と挿入

[編集]

#include <cassert>
#include <deque>
#include <list>
 
int main()
{
    auto head = std::deque{1, 2, 3, 4};
    const auto tail = std::list{-5, -6, -7};
#ifdef __cpp_lib_containers_ranges
    head.append_range(tail);
#else
    head.insert(head.end(), tail.cbegin(), tail.cend());
#endif
    assert((head == std::deque{1, 2, 3, 4, -5, -6, -7}));
}

[編集] 関連項目

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