iter_move(std::move_iterator)

Casts the result of dereferencing the underlying iterator to its associated rvalue reference type.

# Declarations

friend constexpr std::iter_rvalue_reference_t<Iter>
iter_move( const std::move_iterator& i ) noexcept(/* see below */);

(since C++20)

# Parameters

# Return value

An rvalue reference or a prvalue temporary.

# Example

#include <iomanip>
#include <iostream>
#include <iterator>
#include <string>
#include <vector>
 
void print(const auto& rem, const auto& v)
{
    std::cout << rem << '[' << size(v) << "] { ";
    for (char comma[]{0, ' ', 0}; const auto& s : v)
        std::cout << comma << std::quoted(s), comma[0] = ',';
    std::cout << " }\n";
}
 
int main()
{
    std::vector<std::string> p{"Andromeda", "Cassiopeia", "Phoenix"}, q;
 
    print("p", p), print("q", q);
 
    using MI = std::move_iterator<std::vector<std::string>::iterator>;
 
    for (MI first{p.begin()}, last{p.end()}; first != last; ++first)
        q.emplace_back(/* ADL */ iter_move(first));
 
    print("p", p), print("q", q);
}

# See also