std::make_move_iterator
Материал из cppreference.com
|
|
Эта страница была переведена автоматически с английской версии вики используя Переводчик Google. Перевод может содержать ошибки и странные формулировки. Наведите курсор на текст, чтобы увидеть оригинал. Щёлкните здесь, чтобы увидеть английскую версию этой страницы. (Вы можете помочь в исправлении ошибок и улучшении перевода. Для инструкций перейдите по ссылке.) |
<metanoindex/>
<tbody> </tbody>| Определено в заголовочном файле <iterator>
|
||
template< class Iterator > std::move_iterator<Iterator> make_move_iterator( const Iterator& i ); |
(начиная с C++11) | |
make_move_iterator является шаблоном удобная функция, которая строит std::move_iterator для данного итератора i с типом выводится из типа аргумента.Оригинал:
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.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Параметры
| i | — | итератор ввода должны быть преобразованы, чтобы переместить итератор
Оригинал: input iterator to be converted to move iterator Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
Возвращаемое значение
std::move_iterator, которые могут быть использованы для перемещения из элементов доступны через
iОригинал:
A std::move_iterator which can be used to move from the elements accessed through
iТекст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Возможная реализация
template< class Iterator >
std::move_iterator<Container> make_move_iterator( const Iterator& i)
{
return std::move_iterator<Iterator>(i);
}
|
Пример
Запустить этот код
#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';
}
Вывод:
v1 now holds: "one" "two" "three"
v2 now holds: "one" "two" "three"
original list now holds: "" "" ""
См. также
(C++11) |
адаптер итератора, который разыменовывается в правостороннюю ссылку (шаблон класса) |
(C++11) |
получает ссылку на rvalue (шаблон функции) |