Namespaces
Variants

std::move_iterator<Iter>:: 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)
move_iterator ( ) ;
(1) (constexpr depuis C++17)
explicit move_iterator ( iterator_type x ) ;
(2) (constexpr depuis C++17)
template < class U >
move_iterator ( const move_iterator < U > & other ) ;
(3) (constexpr depuis C++17)

Construit un nouveau move_iterator .

Surcharge current
(1) initialisé par valeur
(2) initialisé avec x (jusqu'à C++20) std :: move ( x ) (depuis C++20)
(3) initialisé avec other. current
3) Le constructeur de conversion.

Si U n'est pas convertible en Iter , le programme est mal formé.

(jusqu'à C++20)

Cette surcharge participe à la résolution de surcharge seulement si std:: is_same_v < U, Iter > est false et std:: convertible_to < const U & , Iter > est satisfait.

(depuis C++20)

Table des matières

Paramètres

x - itérateur à adapter
other - adaptateur d'itérateur à copier

Exemple

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Appliqué à Comportement publié Comportement corrigé
LWG 3435 C++20 la surcharge ( 3 ) n'était pas contrainte contrainte

Voir aussi

assigne un autre move_iterator
(fonction membre publique)
crée un std::move_iterator dont le type est déduit de l'argument
(fonction template)