Namensräume
Varianten
Aktionen

std::inserter

Von cppreference.com
< cpp‎ | iterator
 
 
Iterator-Bibliothek
Iterator-Konzepte
Iterator-Primitive
Algorithmus-Konzepte und Hilfsprogramme
Indirekte aufrufbare Konzepte
Gemeinsame Algorithmus-Anforderungen
(C++20)
(C++20)
(C++20)
Dienstprogramme
(C++20)
Iterator-Adapter
Bereichszugriff
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
Definiert in Header <iterator>
template< class Container >

std::insert_iterator<Container>

    inserter( Container& c, typename Container::iterator i );
(bis C++20)
template< class Container >

constexpr std::insert_iterator<Container>

    inserter( Container& c, ranges::iterator_t<Container> i );
(seit C++20)

inserter ist eine Hilfsfunktion-Schablone, die einen std::insert_iterator für den Container c und dessen Iterator i konstruiert, wobei der Typ aus dem Argumenttyp abgeleitet wird.

Inhalt

[bearbeiten] Parameter

c - Container, der eine insert-Operation unterstützt
i - Iterator in c, der die Einfügeposition angibt

[bearbeiten] Rückgabewert

Ein std::insert_iterator, der verwendet werden kann, um Elemente in den Container c an der von i angegebenen Position einzufügen.

[bearbeiten] Mögliche Implementierung

template<class Container>
std::insert_iterator<Container> inserter(Container& c, typename Container::iterator i)
{
    return std::insert_iterator<Container>(c, i);
}

[bearbeiten] Beispiel

#include <algorithm>
#include <iostream>
#include <iterator>
#include <set>
#include <vector>
 
int main()
{
    std::multiset<int> s{1, 2, 3};
 
    // std::inserter is commonly used with multi-sets
    std::fill_n(std::inserter(s, s.end()), 5, 2);
 
    for (int n : s)
        std::cout << n << ' ';
    std::cout << '\n';
 
    std::vector<int> d{100, 200, 300};
    std::vector<int> v{1, 2, 3, 4, 5};
 
    // when inserting in a sequence container, insertion point advances
    // because each std::insert_iterator::operator= updates the target iterator
    std::copy(d.begin(), d.end(), std::inserter(v, std::next(v.begin())));
 
    for (int n : v)
        std::cout << n << ' ';
    std::cout << '\n';
}

Ausgabe

1 2 2 2 2 2 2 3 
1 100 200 300 2 3 4 5

[bearbeiten] Defect Reports

Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 561 C++98 Der Typ von i war unabhängig von Container Es ist der Iteratortyp von Container

[bearbeiten] Siehe auch

Iterator-Adapter für die Einfügung in einen Container
(Klassenvorlage) [bearbeiten]
erstellt einen std::back_insert_iterator vom Typ, der aus dem Argument abgeleitet wird
(Funktionsvorlage) [bearbeiten]
erstellt einen std::front_insert_iterator vom Typ, der aus dem Argument abgeleitet wird
(Funktionsvorlage) [bearbeiten]