std::inserter
Von cppreference.com
| Definiert in Header <iterator> |
||
template< class Container > std::insert_iterator<Container> |
(bis C++20) | |
| template< class Container > constexpr std::insert_iterator<Container> |
(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
Führen Sie diesen Code aus
#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) | |
| erstellt einen std::back_insert_iterator vom Typ, der aus dem Argument abgeleitet wird (Funktionsvorlage) | |
| erstellt einen std::front_insert_iterator vom Typ, der aus dem Argument abgeleitet wird (Funktionsvorlage) |