Namespaces
Variants

std::reverse_iterator<Iter>:: operator=

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)
template < class U >
reverse_iterator & operator = ( const reverse_iterator < U > & other ) ;
(constexpr depuis C++17)

Assigne other. current à current .

Cette surcharge participe à la résolution de surcharge seulement si std:: is_same_v < U, Iter > est false et que les deux std:: convertible_to < const U & , Iter > et std:: assignable_from < Iter & , const U & > sont satisfaits.

(depuis C++20)

Table des matières

Paramètres

autre - adaptateur d'itérateur pour assigner

Valeur de retour

* this

Exemple

#include <iostream>
#include <iterator>
int main()
{
    const int a1[]{0, 1, 2};
    int a2[]{0, 1, 2, 3};
    short a3[]{40, 41, 42};
    std::reverse_iterator<const int*> it1{std::crbegin(a1)};
    it1 = std::reverse_iterator<int*>{std::rbegin(a2)};   // OK
//  it1 = std::reverse_iterator<short*>{std::rbegin(a3)}; // Erreur de compilation :
                                                          // types de pointeurs incompatibles
    std::reverse_iterator<const short*> it2{nullptr};
    it2 = std::rbegin(a3); // OK
//  it2 = std::begin(a3);  // Erreur de compilation : aucune surcharge d'opérateur= viable
    std::cout << *it2 << '\n';
}

Sortie :

42

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 280 C++98 l'assignation hétérogène n'était pas autorisée autorisée
LWG 3435 C++20 l'opérateur d'assignation de conversion n'était pas contraint contraint

Voir aussi

construit un nouveau reverse_iterator
(fonction membre publique)