std:: back_insert_iterator
|
Определено в заголовочном файле
<iterator>
|
||
|
template
<
class
Container
>
class
back_insert_iterator
|
(до C++17) | |
|
template
<
class
Container
>
class back_insert_iterator ; |
(начиная с C++17) | |
std::back_insert_iterator
является
LegacyOutputIterator
, который добавляет элементы в контейнер, для которого он был создан. Функция-член контейнера
push_back()
вызывается каждый раз, когда итератор (разыменованный или нет) присваивается. Инкремент
std::back_insert_iterator
не имеет эффекта.
Содержание |
Типы членов
| Тип члена | Определение | ||||
iterator_category
|
std:: output_iterator_tag | ||||
value_type
|
void | ||||
difference_type
|
|
||||
pointer
|
void | ||||
reference
|
void | ||||
container_type
|
Container
|
|
Типы членов
|
(до C++17) |
Функции-члены
создает новый
back_insert_iterator
(публичная функция-член) |
|
|
вставляет объект в ассоциированный контейнер
(публичная функция-член) |
|
|
пустая операция
(публичная функция-член) |
|
|
пустая операция
(публичная функция-член) |
Объекты-члены
| Название члена | Определение |
container
(защищённый)
|
указатель типа
Container*
|
Пример
#include <algorithm> #include <iostream> #include <iterator> #include <vector> int main() { std::vector<int> v; std::generate_n( std::back_insert_iterator<std::vector<int>>(v), // Или использовать вспомогательную функцию std::back_inserter // Или использовать синтаксис C++17 std::back_insert_iterator(v) 10, [n = 0]() mutable { return ++n; } ); for (int n : v) std::cout << n << ' '; std::cout << '\n'; }
Вывод:
1 2 3 4 5 6 7 8 9 10
Смотрите также
|
создаёт
std::back_insert_iterator
с типом, выведенным из аргумента
(шаблон функции) |
|
|
адаптер итератора для вставки в начало контейнера
(шаблон класса) |
|
|
адаптер итератора для вставки в контейнер
(шаблон класса) |