Namespaces
Variants

std:: make_move_iterator

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
헤더에 정의됨 <iterator>
template < class Iter >
std:: move_iterator < Iter > make_move_iterator ( Iter i ) ;
(C++11부터)
(C++17부터 constexpr)

make_move_iterator 는 주어진 반복자 i 에 대해 인자의 타입으로부터 추론된 타입으로 std::move_iterator 를 생성하는 편의 함수 템플릿입니다.

목차

매개변수

i - 이동 반복자로 변환할 입력 반복자

반환값

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

예제

#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()); // 복사
    std::vector<std::string> v2(std::make_move_iterator(s.begin()),
                                std::make_move_iterator(s.end())); // 이동
    print("v1 now holds: ", v1);
    print("v2 now holds: ", v2);
    print("original list now holds: ", s);
}

가능한 출력:

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

결함 보고서

다음의 동작 변경 결함 보고서들은 이전에 발표된 C++ 표준에 소급 적용되었습니다.

DR 적용 대상 게시된 동작 올바른 동작
LWG 2061 C++11 make_move_iterator 가 배열 인수를 포인터로 변환하지 않았음 변환하도록 수정됨

참고 항목

역참조 시 rvalue를 반환하는 iterator 어댑터
(클래스 템플릿)
(C++11)
인수를 xvalue로 변환
(함수 템플릿)