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 desde C++17)

Asigna other. current a current .

Esta sobrecarga participa en la resolución de sobrecarga solo si std:: is_same_v < U, Iter > es false y tanto std:: convertible_to < const U & , Iter > como std:: assignable_from < Iter & , const U & > se cumplen.

(desde C++20)

Contenidos

Parámetros

otro - adaptador de iterador para asignar

Valor de retorno

* this

Ejemplo

#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)}; // Error de compilación:
                                                          // tipos de puntero incompatibles
    std::reverse_iterator<const short*> it2{nullptr};
    it2 = std::rbegin(a3); // OK
//  it2 = std::begin(a3);  // Error de compilación: no hay operador= viable sobrecargado
    std::cout << *it2 << '\n';
}

Salida:

42

Informes de defectos

Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.

DR Aplicado a Comportamiento publicado Comportamiento correcto
LWG 280 C++98 la asignación heterogénea no estaba permitida permitida
LWG 3435 C++20 el operador de asignación de conversión no estaba restringido restringido

Véase también

construye un nuevo reverse_iterator
(función miembro pública)