void splice_after( const_iterator pos, forward_list& other ); | (1) | (since C++11) |
void splice_after( const_iterator pos, forward_list&& other ); | (1) | (since C++11) |
void splice_after( const_iterator pos, forward_list& other, const_iterator it ); | (2) | (since C++11) |
void splice_after( const_iterator pos, forward_list&& other, const_iterator it ); | (2) | (since C++11) |
void splice_after( const_iterator pos, forward_list& other, const_iterator first, const_iterator last ); | (3) | (since C++11) |
void splice_after( const_iterator pos, forward_list&& other, const_iterator first, const_iterator last ); | (3) | (since C++11) |
Moves elements from another forward_list
to *this
.
No elements are copied. pos
must be either a dereferenceable valid iterator into *this
or the before_begin()
iterator (in particular, end()
is not a valid argument for pos
). The behavior is undefined if get_allocator() != other.get_allocator()
. No iterators or references become invalidated, the iterators to the moved elements now refer into *this
, not into other
.
other
into *this
. The elements are inserted after the element pointed to by pos
. The container other
becomes empty after the operation. The behavior is undefined if other
refers to the same object as *this
.it
from other
into *this
. The element is inserted after the element pointed to by pos
. Has no effect if pos == it
or if pos == ++it
.(first, last)
from other
into *this
. The elements are inserted after the element pointed to by pos
. The element pointed-to by first
is not moved. The behavior is undefined if pos
is an iterator in the range (first, last)
.pos | - | element after which the content will be inserted |
other | - | another container to move the content from |
it | - | iterator preceding the iterator to the element to move from other to *this |
first, last | - | the range of elements to move from other to *this |
(none).
Throws nothing.
other
std::distance(first, last)
#include <algorithm> #include <cassert> #include <forward_list> #include <initializer_list> #include <iostream> using F = std::forward_list<int>; std::ostream& operator<< (std::ostream& os, F const& l) { for (int e : l) os << e << ' '; return os; } int main() { // Demonstrate the meaning of open interval (first, last) in the 3rd // overload of splice_after(): the first element of l1 is not moved. { F l1 = { 1, 2, 3, 4, 5 }; F l2 = { 10, 11, 12 }; l2.splice_after(l2.cbegin(), l1, l1.cbegin(), l1.cend()); // not equivalent to l2.splice_after(l2.cbegin(), l1); // which is equivalent to // l2.splice_after(l2.cbegin(), l1, l1.cbefore_begin(), l1.end()); std::cout << "l1: " << l1 << "\n" "l2: " << l2 << '\n'; } // Compare two given lists and abort the program if they are not equal. auto assert_equ = [] (F const& p, std::initializer_list<int> const& q) { assert(std::ranges::equal(p, q)); }; // The following code demonstrates all three overloads (1),..(3). { F x = { 1, 2, 3, 4, 5 }; F y = { 10, 11, 12 }; x.splice_after(x.cbegin(), y); // (1) assert_equ( x, { 1, 10, 11, 12, 2, 3, 4, 5 } ); assert_equ( y, { } ); } { F x = { 1, 2, 3, 4, 5 }; F y = { 10, 11, 12 }; x.splice_after(x.cbegin(), y, y.cbegin()); // (2) assert_equ( x, { 1, 11, 2, 3, 4, 5 } ); assert_equ( y, { 10, 12 } ); } { F x = { 1, 2, 3, 4, 5 }; F y = { 10, 11, 12 }; x.splice_after(x.cbegin(), y, y.cbegin(), y.cend()); // (3) assert_equ( x, { 1, 11, 12, 2, 3, 4, 5 } ); assert_equ( y, { 10 } ); } }
Output:
l1: 1 l2: 10 2 3 4 5 11 12
(C++11) | merges two sorted lists (public member function) |
(C++11) | removes elements satisfying specific criteria (public member function) |
(C++11) | returns an iterator to the element before beginning (public member function) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/container/forward_list/splice_after