Namensräume
Varianten
Aktionen

std::make_move_iterator

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 Iter >
std::move_iterator<Iter> make_move_iterator( Iter i );
(seit C++11)
(constexpr seit C++17)

make_move_iterator ist eine Hilfsfunktion-Vorlage, die einen std::move_iterator für den gegebenen Iterator i mit dem aus dem Typ des Arguments abgeleiteten Typ konstruiert.

Inhalt

[bearbeiten] Parameter

i - Eingabe-Iterator, der in einen Move-Iterator konvertiert werden soll

[bearbeiten] Rückgabewert

std::move_iterator<Iter>(std::move(i))

[bearbeiten] Beispiel

#include <iomanip>
#include <iostream>
#include <iterator>
#include <list>
#include <string>
#include <vector>
 
auto print = [](const auto rem, const auto& seq)
{
    for (std::cout << rem; const auto& str : seq)
        std::cout << std::quoted(str) << ' ';
    std::cout << '\n';
};
 
int main()
{
    std::list<std::string> s{"one", "two", "three"};
 
    std::vector<std::string> v1(s.begin(), s.end()); // copy
 
    std::vector<std::string> v2(std::make_move_iterator(s.begin()),
                                std::make_move_iterator(s.end())); // move
 
    print("v1 now holds: ", v1);
    print("v2 now holds: ", v2);
    print("original list now holds: ", s);
}

Mögliche Ausgabe

v1 now holds: "one" "two" "three" 
v2 now holds: "one" "two" "three" 
original list now holds: "" "" ""

[bearbeiten] Fehlerberichte

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 2061 C++11 make_move_iterator konvertierte Array-Argumente nicht in Zeiger wurde zur Konvertierung gemacht

[bearbeiten] Siehe auch

Iterator-Adapter, der zu einem rvalue dereferenziert
(Klassenvorlage) [bearbeiten]
(C++11)
konvertiert das Argument in ein xvalue
(Funktionsvorlage) [edit]