Namespaces
Variants

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

Construye un nuevo reverse_iterator .

Sobrecarga current
(1) inicializado por valor
(2) inicializado con x
(3) inicializado con other. current
3) El constructor de conversión.

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

(desde C++20)

Contenidos

Parámetros

x - iterador a adaptar
other - adaptador de iterador a copiar

Ejemplo

#include <cassert>
#include <concepts>
#include <iterator>
#include <vector>
int main()
{
    std::vector v{0, 1, 2, 3, 4};
    using ReverseIt = std::reverse_iterator<std::vector<int>::const_iterator>;
    ReverseIt i1; // sobrecarga (1)
    i1 = v.crbegin();
    assert(*i1 == 4);
    ReverseIt i2(i1); // sobrecarga (2)
    assert(i2[0] == 4);
    int x[]{1, 2, 3};
    auto i3 = std::reverse_iterator<int*>(x + std::size(x)); // sobrecarga (1)
    i3[0] = -3;
    assert(x[2] == -3);
    std::reverse_iterator<int const*> i4(i3); // sobrecarga (3): int => const int
    static_assert(std::convertible_to<decltype(i3)::value_type,
                                      decltype(i4)::value_type>);
    // i4[0] = 5; // Error: asignación de ubicación de solo lectura
}

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 235 C++98 el efecto de la sobrecarga ( 1 ) no estaba especificado especificado
LWG 1012 C++98 la sobrecarga ( 1 ) inicializaba por defecto current se inicializa por valor
LWG 3435 C++20 la sobrecarga ( 3 ) no estaba restringida restringida

Véase también

asigna otro reverse_iterator
(función miembro pública)
crea un std::reverse_iterator de tipo inferido del argumento
(plantilla de función)