operator==,!=,<,<=,>,>=,<=> (std::reverse_iterator)
|
Definiert im Header
<iterator>
|
||
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
==
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(1) | (constexpr seit C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
!
=
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(2) | (constexpr seit C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
<
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(3) | (constexpr seit C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
<=
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(4) | (constexpr seit C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
>
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(5) | (constexpr seit C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
>=
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(6) | (constexpr seit C++17) |
|
template
<
class
Iter1,
std::
three_way_comparable_with
<
Iter1
>
Iter2
>
constexpr
std::
compare_three_way_result_t
<
Iter1, Iter2
>
|
(7) | (seit C++20) |
Vergleicht die zugrundeliegenden Iteratoren von lhs und rhs .
- Die Ergebnisse von Gleichheitsvergleichen bleiben erhalten (d.h. gleiche zugrundeliegende Iteratoren implizieren gleiche Reverse-Iteratoren).
- Die Ergebnisse von relationalen Vergleichen werden umgekehrt (d.h. ein größerer zugrundeliegender Iterator impliziert einen kleineren Reverse-Iterator).
|
1)
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn
lhs.
base
(
)
==
rhs.
base
(
)
wohlgeformt und in
bool
konvertierbar ist.
2)
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn
lhs.
base
(
)
!
=
rhs.
base
(
)
wohlgeformt und in
bool
konvertierbar ist.
3)
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn
lhs.
base
(
)
>
rhs.
base
(
)
wohlgeformt und in
bool
konvertierbar ist.
4)
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn
lhs.
base
(
)
>=
rhs.
base
(
)
wohlgeformt und in
bool
konvertierbar ist.
5)
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn
lhs.
base
(
)
<
rhs.
base
(
)
wohlgeformt und in
bool
konvertierbar ist.
6)
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn
lhs.
base
(
)
<=
rhs.
base
(
)
wohlgeformt und in
bool
konvertierbar ist.
|
(seit C++20) |
Inhaltsverzeichnis |
Parameter
| lhs, rhs | - | Iterator-Adapter zum Vergleichen |
Rückgabewert
Hinweise
operator <=> gibt rhs. base ( ) <=> lhs. base ( ) zurück und nicht lhs. base ( ) <=> rhs. base ( ) , da es sich um einen Reverse-Iterator handelt.
Beispiel
#include <cassert> #include <iterator> int main() { int a[]{0, 1, 2, 3}; // ↑ └───── x, y // └──────── z // “x” und “y” sind gleich, aber “x” ist kleiner als “z” (umgekehrt) std::reverse_iterator<int*> x{std::rend(a) - std::size(a)}, y{std::rend(a) - std::size(a)}, z{std::rbegin(a) + 1}; // Zwei-Wege-Vergleiche assert( x == y ); assert(!(x != y)); assert(!(x < y)); assert( x <= y ); assert(!(x == z)); assert( x != z ); assert( x < z ); assert( x <= z ); // Drei-Wege-Vergleiche assert( x <=> y == 0 ); assert(!(x <=> y < 0)); assert(!(x <=> y > 0)); assert(!(x <=> z == 0)); assert( x <=> z < 0 ); assert(!(x <=> z > 0)); }
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 280 | C++98 | heterogene Zuweisung war nicht erlaubt | erlaubt |