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

Construit un nouveau reverse_iterator .

Surcharge current
(1) initialisé par défaut
(2) initialisé avec x
(3) initialisé avec other. current
3) Le constructeur de conversion.

Cette surcharge participe à la résolution de surcharge seulement si std:: is_same_v < U, Iter > est false et que 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

#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; // surcharge (1)
    i1 = v.crbegin();
    assert(*i1 == 4);
    ReverseIt i2(i1); // surcharge (2)
    assert(i2[0] == 4);
    int x[]{1, 2, 3};
    auto i3 = std::reverse_iterator<int*>(x + std::size(x)); // surcharge (1)
    i3[0] = -3;
    assert(x[2] == -3);
    std::reverse_iterator<int const*> i4(i3); // surcharge (3): int => const int
    static_assert(std::convertible_to<decltype(i3)::value_type,
                                      decltype(i4)::value_type>);
    // i4[0] = 5; // Erreur : assignation d'un emplacement en lecture seule
}

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 235 C++98 l'effet de la surcharge ( 1 ) n'était pas spécifié spécifié
LWG 1012 C++98 la surcharge ( 1 ) initialisait par défaut current il est initialisé par valeur
LWG 3435 C++20 la surcharge ( 3 ) n'était pas contrainte contrainte

Voir aussi

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