std::make_move_iterator
Von cppreference.com
| 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
Führen Sie diesen Code aus
#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
| (C++11) |
Iterator-Adapter, der zu einem rvalue dereferenziert (Klassenvorlage) |
| (C++11) |
konvertiert das Argument in ein xvalue (Funktionsvorlage) |