Namespaces
Variants

std::insert_iterator<Container>:: operator=

From cppreference.net

Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
(1)
insert_iterator < Container > &
operator = ( typename Container :: const_reference value ) ;
(до C++11)
insert_iterator < Container > &
operator = ( const typename Container :: value_type & value ) ;
(начиная с C++11)
(до C++20)
constexpr insert_iterator < Container > &
operator = ( const typename Container :: value_type & value ) ;
(начиная с C++20)
(2)
insert_iterator < Container > &
operator = ( typename Container :: value_type && value ) ;
(начиная с C++11)
(до C++20)
constexpr insert_iterator < Container > &
operator = ( typename Container :: value_type && value ) ;
(начиная с C++20)

Вставляет заданное значение value в контейнер.

1) Результат: iter = container - > insert ( iter, value ) ; ++ iter ; .
2) Приводит к iter = container - > insert ( iter, std :: move ( value ) ) ; ++ iter ; .

Содержание

Параметры

value - значение для вставки

Возвращаемое значение

* this

Примечания

Эта функция использует совместимость сигнатур между подсказывающей вставкой для ассоциативных контейнеров (таких как std::set::insert ) и позиционной вставкой для последовательных контейнеров (таких как std::vector::insert ).

Пример

#include <deque>
#include <iostream>
#include <iterator>
int main()
{
    std::deque<int> q;
    std::insert_iterator<std::deque<int>> it(q, q.begin());
    for (int i = 0; i < 10; ++i)
        it = i; // вставляет i
    for (auto& elem : q)
        std::cout << elem << ' ';
    std::cout << '\n';
}

Вывод:

0 1 2 3 4 5 6 7 8 9