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 seit C++17)
explicit reverse_iterator ( iterator_type x ) ;
(2) (constexpr seit C++17)
template < class U >
reverse_iterator ( const reverse_iterator < U > & other ) ;
(3) (constexpr seit C++17)

Konstruiert einen neuen reverse_iterator .

Überladung current
(1) wertinitialisiert
(2) initialisiert mit x
(3) initialisiert mit other. current
3) Der konvertierende Konstruktor.

Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn std:: is_same_v < U, Iter > false ist und std:: convertible_to < const U & , Iter > modelliert wird.

(seit C++20)

Inhaltsverzeichnis

Parameter

x - zu adaptierender Iterator
other - zu kopierender Iterator-Adapter

Beispiel

#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; // Überladung (1)
    i1 = v.crbegin();
    assert(*i1 == 4);
    ReverseIt i2(i1); // Überladung (2)
    assert(i2[0] == 4);
    int x[]{1, 2, 3};
    auto i3 = std::reverse_iterator<int*>(x + std::size(x)); // Überladung (1)
    i3[0] = -3;
    assert(x[2] == -3);
    std::reverse_iterator<int const*> i4(i3); // Überladung (3): int => const int
    static_assert(std::convertible_to<decltype(i3)::value_type,
                                      decltype(i4)::value_type>);
    // i4[0] = 5; // Fehler: Zuweisung an schreibgeschützten Speicherort
}

Fehlerberichte

Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR Angewendet auf Verhalten wie veröffentlicht Korrektes Verhalten
LWG 235 C++98 die Wirkung der Überladung ( 1 ) war nicht spezifiziert spezifiziert
LWG 1012 C++98 Überladung ( 1 ) standardinitialisierte current sie wird wertinitialisiert
LWG 3435 C++20 Überladung ( 3 ) war nicht eingeschränkt eingeschränkt

Siehe auch

weist einen anderen reverse_iterator zu
(öffentliche Elementfunktion)
erstellt einen std::reverse_iterator mit vom Argument abgeleitetem Typ
(Funktionstemplate)