名前空間
変種
操作

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

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

rg の要素のコピーを、反転させずに pos の前に挿入します。

すべてのイテレータ(end() イテレータを含む)は無効になります。参照も無効になります。ただし、pos == begin() または pos == end() の場合は、無効になりません。

rg の各イテレータはちょうど1回逆参照されます。

rg はコンテナと重複してはいけません。重複した場合、動作は未定義となります。

目次

[編集] パラメータ

pos - 挿入される要素の前に位置するイテレータ(posend() イテレータでもよい)
rg - コンテナ互換範囲。つまり、要素が T に変換可能な input_range
型要件
-
T*ranges::begin(rg) から EmplaceConstructible である必要がある。また、TMoveInsertable でなければならず、TMoveConstructibleMoveAssignable、および Swappable を満たす必要がある。それ以外の場合、動作は未定義である。

[編集] 戻り値

挿入された最初の要素のコピーを指す iterator、または rg が空の場合は pos

注釈

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

[編集]

#include <algorithm>
#include <cassert>
#include <iterator>
#include <deque>
#include <list>
 
int main()
{
    auto container = std::deque{1, 2, 3, 4};
    auto pos = std::next(container.begin(), 2);
    assert(*pos == 3);
    const auto rg = std::list{-1, -2, -3};
 
#ifdef __cpp_lib_containers_ranges
    container.insert_range(pos, rg);
#else
    container.insert(pos, rg.cbegin(), rg.cend());
#endif
    assert(std::ranges::equal(container, std::deque{1, 2, -1, -2, -3, 3, 4}));
}

[編集] 関連項目

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