std::forward_list<T,Allocator>::insert_range_after
From cppreference.com
< cpp | container | forward list
| template< container-compatible-range<T> R > iterator insert_range_after( const_iterator pos, R&& rg ); |
(C++23から) | |
rg の要素のコピーを、逆順ではない順序で pos の後(before)に挿入します。範囲 rg 内の各イテレータはちょうど1回だけ間接参照されます。
pos は、範囲 [begin(), end()) 内のデリファレンス可能な任意のイテレータ、または before_begin() イテレータでなければなりません(したがって、end() は pos の有効な引数ではありません)。
イテレータや参照は無効になりません。
rg がコンテナと重なる場合、動作は未定義です。
目次 |
[編集] パラメータ
| pos | - | コンテンツが挿入されるイテレータ |
| rg | - | コンテナ互換範囲。つまり、要素が T に変換可能な input_range |
| 型要件 | ||
-*ranges::begin(rg) から forward_list への EmplaceConstructible である必要があります。そうでなければ、動作は未定義です。 | ||
[編集] 戻り値
forward_list に挿入された最後の要素のコピーを指す iterator、または rg が空の場合は pos を指すイテレータ。
[編集] 計算量
rg のサイズに対して線形。
[編集] 注釈
| 機能テストマクロ | 値 | 規格 | 機能 |
|---|---|---|---|
__cpp_lib_containers_ranges |
202202L |
(C++23) | ranges対応の構築と挿入 |
[編集] 例
このコードを実行
#include <algorithm> #include <cassert> #include <forward_list> #include <iterator> #include <vector> int main() { auto container = std::forward_list{1, 2, 3, 4}; auto pos = std::next(container.cbegin()); assert(*pos == 2); const auto rg = std::vector{-1, -2, -3}; #ifdef __cpp_lib_containers_ranges container.insert_range_after(pos, rg); #else container.insert_after(pos, rg.cbegin(), rg.cend()); #endif assert(std::ranges::equal(container, std::vector{1, 2, -1, -2, -3, 3, 4})); }
[編集] 関連項目
| (C++23) |
先頭に要素の範囲を追加する (public member function) |
| 指定した要素の直後に要素を挿入する (public member function) | |
| 指定した要素の直後に要素を直接構築する (public member function) |