名前空間
変種
操作

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

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

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

イテレータや参照は無効化されない。

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

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

目次

[編集] パラメータ

pos - コンテンツが挿入される位置のイテレータ(posend() イテレータでも構いません)
rg - コンテナ互換範囲。つまり、要素が T に変換可能な input_range
型要件
-
T は、*ranges::begin(rg) から listEmplaceConstructible である必要があります。そうでない場合、動作は未定義となります。

[編集] 戻り値

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

注釈

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

[編集]

#include <algorithm>
#include <cassert>
#include <iterator>
#include <list>
#include <vector>
 
int main()
{
    auto container = std::list{1, 2, 3, 4};
    auto pos = std::next(container.begin(), 2);
    assert(*pos == 3);
    const auto rg = std::vector{-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::list{1, 2, -1, -2, -3, 3, 4}));
}

[編集] 関連項目

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