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

Weist other. current an current zu.

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

(seit C++20)

Inhaltsverzeichnis

Parameter

other - Iterator-Adapter zur Zuweisung

Rückgabewert

* this

Beispiel

#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)}; // Kompilierungsfehler:
                                                          // inkompatible Zeigertypen
    std::reverse_iterator<const short*> it2{nullptr};
    it2 = std::rbegin(a3); // OK
//  it2 = std::begin(a3);  // Kompilierungsfehler: kein passender operator= Überladung
    std::cout << *it2 << '\n';
}

Ausgabe:

42

Fehlerberichte

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

DR Angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 280 C++98 heterogene Zuweisung war nicht erlaubt erlaubt
LWG 3435 C++20 der konvertierende Zuweisungsoperator war nicht eingeschränkt eingeschränkt

Siehe auch

Konstruiert einen neuen reverse_iterator
(öffentliche Member-Funktion)