operator==,!=,<,<=,>,>=,<=> (std::reverse_iterator)
|
Défini dans l'en-tête
<iterator>
|
||
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
==
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(1) | (constexpr depuis C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
!
=
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(2) | (constexpr depuis C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
<
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(3) | (constexpr depuis C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
<=
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(4) | (constexpr depuis C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
>
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(5) | (constexpr depuis C++17) |
|
template
<
class
Iter1,
class
Iter2
>
bool
operator
>=
(
const
std::
reverse_iterator
<
Iter1
>
&
lhs,
|
(6) | (constexpr depuis C++17) |
|
template
<
class
Iter1,
std::
three_way_comparable_with
<
Iter1
>
Iter2
>
constexpr
std::
compare_three_way_result_t
<
Iter1, Iter2
>
|
(7) | (depuis C++20) |
Compare les itérateurs sous-jacents de lhs et rhs .
- Le résultat des comparaisons d'égalité est préservé (c'est-à-dire que des itérateurs sous-jacents égaux impliquent des itérateurs inversés égaux).
- Le résultat des comparaisons relationnelles est inversé (c'est-à-dire qu'un itérateur sous-jacent supérieur implique un itérateur inversé inférieur).
|
1)
Cette surcharge participe à la résolution de surcharge uniquement si
lhs.
base
(
)
==
rhs.
base
(
)
est bien formée et convertible en
bool
.
2)
Cette surcharge participe à la résolution de surcharge uniquement si
lhs.
base
(
)
!
=
rhs.
base
(
)
est bien formée et convertible en
bool
.
3)
Cette surcharge participe à la résolution de surcharge uniquement si
lhs.
base
(
)
>
rhs.
base
(
)
est bien formée et convertible en
bool
.
4)
Cette surcharge participe à la résolution de surcharge uniquement si
lhs.
base
(
)
>=
rhs.
base
(
)
est bien formée et convertible en
bool
.
5)
Cette surcharge participe à la résolution de surcharge uniquement si
lhs.
base
(
)
<
rhs.
base
(
)
est bien formée et convertible en
bool
.
6)
Cette surcharge participe à la résolution de surcharge uniquement si
lhs.
base
(
)
<=
rhs.
base
(
)
est bien formée et convertible en
bool
.
|
(depuis C++20) |
Table des matières |
Paramètres
| lhs, rhs | - | adaptateurs d'itérateur pour comparer |
Valeur de retour
Notes
operator <=> retourne rhs. base ( ) <=> lhs. base ( ) plutôt que lhs. base ( ) <=> rhs. base ( ) car il s'agit d'un itérateur inverse.
Exemple
#include <cassert> #include <iterator> int main() { int a[]{0, 1, 2, 3}; // ↑ └───── x, y // └──────── z // “x” et “y” sont égaux, mais “x” est inférieur à “z” (inversement) std::reverse_iterator<int*> x{std::rend(a) - std::size(a)}, y{std::rend(a) - std::size(a)}, z{std::rbegin(a) + 1}; // comparaisons binaires assert( x == y ); assert(!(x != y)); assert(!(x < y)); assert( x <= y ); assert(!(x == z)); assert( x != z ); assert( x < z ); assert( x <= z ); // comparaisons à trois voies assert( x <=> y == 0 ); assert(!(x <=> y < 0)); assert(!(x <=> y > 0)); assert(!(x <=> z == 0)); assert( x <=> z < 0 ); assert(!(x <=> z > 0)); }
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 tel que publié | Comportement correct |
|---|---|---|---|
| LWG 280 | C++98 | l'assignation hétérogène n'était pas autorisée | autorisée |