std::forward_list<T,Allocator>:: insert_after
|
iterator insert_after
(
const_iterator pos,
const
T
&
value
)
;
|
(1) |
(начиная с C++11)
(constexpr начиная с C++26) |
|
iterator insert_after
(
const_iterator pos, T
&&
value
)
;
|
(2) |
(начиная с C++11)
(constexpr начиная с C++26) |
|
iterator insert_after
(
const_iterator pos,
size_type count, const T & value ) ; |
(3) |
(начиная с C++11)
(constexpr начиная с C++26) |
|
template
<
class
InputIt
>
iterator insert_after
(
const_iterator pos,
|
(4) |
(начиная с C++11)
(constexpr начиная с C++26) |
|
iterator insert_after
(
const_iterator pos,
std:: initializer_list < T > ilist ) ; |
(5) |
(начиная с C++11)
(constexpr начиная с C++26) |
Вставляет элементы после указанной позиции в контейнере. Если pos является before_begin() , первый вставленный элемент (если существует) станет первым элементом * this .
Если
pos
находится вне диапазона
[
before_begin()
,
end()
)
, поведение не определено.
[
first
,
last
)
после
pos
.
InputIt
удовлетворяет требованиям
LegacyInputIterator
.
-
Tне является EmplaceConstructible вforward_listиз * first . - first или last является итератором на * this .
Никакие итераторы или ссылки не инвалидируются.
Содержание |
Параметры
| pos | - | итератор, после которого будет вставлено содержимое |
| value | - | значение элемента для вставки |
| count | - | количество копий для вставки |
| first, last | - | пара итераторов, определяющая исходный диапазон элементов для вставки |
| ilist | - | список инициализации для вставки значений |
Возвращаемое значение
Исключения
Если исключение выбрасывается по любой причине, эти функции не оказывают никакого эффекта ( strong exception safety guarantee ).
Сложность
Пример
#include <forward_list> #include <iostream> #include <string> #include <vector> void print(const std::forward_list<int>& list) { std::cout << "list: {"; for (char comma[3] = {'\0', ' ', '\0'}; int i : list) { std::cout << comma << i; comma[0] = ','; } std::cout << "}\n"; } int main() { std::forward_list<int> ints{1, 2, 3, 4, 5}; print(ints); // insert_after (2) auto beginIt = ints.begin(); ints.insert_after(beginIt, -6); print(ints); // insert_after (3) auto anotherIt = beginIt; ++anotherIt; anotherIt = ints.insert_after(anotherIt, 2, -7); print(ints); // insert_after (4) const std::vector<int> v = {-8, -9, -10}; anotherIt = ints.insert_after(anotherIt, v.cbegin(), v.cend()); print(ints); // insert_after (5) ints.insert_after(anotherIt, {-11, -12, -13, -14}); print(ints); }
Вывод:
list: {1, 2, 3, 4, 5}
list: {1, -6, 2, 3, 4, 5}
list: {1, -6, -7, -7, 2, 3, 4, 5}
list: {1, -6, -7, -7, -8, -9, -10, 2, 3, 4, 5}
list: {1, -6, -7, -7, -8, -9, -10, -11, -12, -13, -14, 2, 3, 4, 5}
Смотрите также
|
создаёт элементы на месте после элемента
(public member function) |
|
|
вставляет элемент в начало
(public member function) |