- algorithm[meta header]
- std[meta namespace]
- function template[meta id-type]
- cpp11[meta cpp]
namespace std {
template <class InputIterator, class OutputIterator>
OutputIterator
move(InputIterator first,
InputIterator last,
OutputIterator result); // (1) C++11
template <class InputIterator, class OutputIterator>
constexpr OutputIterator
move(InputIterator first,
InputIterator last,
OutputIterator result); // (1) C++20
template <class ExecutionPolicy, class ForwardIterator1,
class ForwardIterator2>
ForwardIterator2
move(ExecutionPolicy&& exec,
ForwardIterator1 first,
ForwardIterator1 last,
ForwardIterator2 result); // (2) C++17
}
イテレータ範囲[first, last)
の要素を出力イテレータ範囲にムーブする。
result
はイテレータ範囲[first,last)
に含まれてはならない。
イテレータ範囲[first,last)
内の要素を、それぞれ出力イテレータ範囲[result,result + (last - first))
へムーブする。
ムーブは first
から順番に行い、0 以上 last - first
未満であるそれぞれの n
について、*(result + n) = std::move(*(first + n))
を行う。
result + (last - first)
正確に last - first
回ムーブ代入が行われる。
#include <algorithm>
#include <iostream>
#include <iterator>
#include <vector>
#include <memory>
int main() {
std::vector<std::unique_ptr<int>> v;
for (int i = 0; i < 5; i++)
v.emplace_back(new int(i));
std::vector<std::unique_ptr<int>> v2;
// v のそれぞれの要素を v2 へムーブする
std::move(v.begin(), v.end(), std::back_inserter(v2));
std::for_each(v2.begin(), v2.end(),
[](const std::unique_ptr<int>& v) { std::cout << *v << std::endl; });
}
- std::move[color ff0000]
- v.emplace_back[link /reference/vector/vector/emplace_back.md]
0
1
2
3
4
template <class InputIterator, class OutputIterator>
OutputIterator move(InputIterator first, InputIterator last, OutputIterator result) {
while (first != last)
*result++ = move(*first++);
return result;
}
- move[link /reference/utility/move.md]
- C++11
- Clang: 3.0 [mark verified]
- GCC: 4.3.6 [mark verified]
- ICC: ??
- Visual C++: 2010 [mark verified], 2012 [mark verified], 2013 [mark verified], 2015 [mark verified]