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++ 标准。

缺陷报告 应用于 发布时的行为 正确行为
LWG 2061 C++11 make_move_iterator 未将数组参数转换为指针 已修改为进行转换

参见

解引用生成右值的迭代器适配器
(类模板)
(C++11)
将实参转换为亡值
(函数模板)