◐ Shell
clean mode source ↗

std::make_move_iterator – cppreference.com

Aus cppreference.com

<metanoindex/>

<tbody> </tbody>

definiert in Header

<iterator>

template< class Iterator > std::move_iterator<Iterator> make_move_iterator( const Iterator& i );

(seit C++11)

make_move_iterator ist eine Komfortfunktion Vorlage, die eine std::move_iterator für die gegebene Iterator i mit dem Typ von der Art der Argumentation ableiten konstruiert .

Original:

make_move_iterator is a convenience function template that constructs a std::move_iterator for the given iterator i with the type deduced from the type of the argument.

The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

Parameter

i -

Ein Iterator umgewandelt Iterator zu bewegen

Original:

input iterator to be converted to move iterator

The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

Rückgabewert

A std::move_iterator die verwendet werden, um aus den Elementen durch i abgerufen verschoben werden kann

Original:

A std::move_iterator which can be used to move from the elements accessed through i

The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

Mögliche Implementierung

template< class Iterator >
std::move_iterator<Container> make_move_iterator( const Iterator& i)
{
    return std::move_iterator<Iterator>(i);
}

Beispiel

#include <iostream>
#include <list>
#include <vector>
#include <string>
#include <iterator>
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

    std::cout << "v1 now holds: ";
    for(auto str : v1)
            std::cout << "\"" << str << "\" ";
    std::cout << "\nv2 now holds: ";
    for(auto str : v2)
            std::cout << "\"" << str << "\" ";
    std::cout << "\noriginal list now holds: ";
    for(auto str : s)
            std::cout << "\"" << str << "\" ";
    std::cout << '\n';
}

Output:

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

Siehe auch

Iterator-Adapter, der dereferenziert zu einem R-Wert auf

Original:

iterator adaptor which dereferences to an rvalue reference

The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.


(Klassen-Template) [edit]

erhält einen rvalue Referenz

Original:

obtains an rvalue reference

The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.


(Funktions-Template) [edit]