std::experimental::ranges:: greater
|
Definiert in Header
<experimental/ranges/functional>
|
||
|
template
<
class
T
=
void
>
requires StrictTotallyOrdered
<
T
>
||
|
(ranges TS) | |
|
template
<>
struct greater < void > ; |
(ranges TS) | |
Funktionsobjekt zum Durchführen von Vergleichen. Die primäre Vorlage ruft
operator
<
auf const Lvalues des Typs
T
mit invertierter Argumentreihenfolge auf. Die Spezialisierung
greater<void>
leitet die Parametertypen des Funktionsaufrufoperators aus den Argumenten ab (aber nicht den Rückgabetyp).
Alle Spezialisierungen von
greater
sind
Semiregular
.
Inhaltsverzeichnis |
Mitgliedertypen
| Mitgliedtyp | Definition |
is_transparent
(nur Mitglied von
greater<void>
Spezialisierung)
|
/* nicht spezifiziert */ |
Memberfunktionen
|
operator()
|
prüft, ob das erste Argument
größer
als das zweite ist
(public member function) |
std::experimental::ranges::greater:: operator()
|
constexpr
bool
operator
(
)
(
const
T
&
x,
const
T
&
y
)
const
;
|
(1) |
(nur Mitglied der primären
greater<T>
-Vorlage)
|
|
template
<
class
T,
class
U
>
requires StrictTotallyOrderedWith
<
T, U
>
||
|
(2) |
(nur Mitglied der
greater<void>
-Spezialisierung)
|
t
und
u
. Entspricht
return
ranges::
less
<>
{
}
(
std::
forward
<
U
>
(
u
)
,
std::
forward
<
T
>
(
t
)
)
;
.
Hinweise
Im Gegensatz zu
std::greater
erfordert
ranges::greater
alle sechs Vergleichsoperatoren
<
,
<=
,
>
,
>=
,
==
und
!=
gültig zu sein (über die
StrictTotallyOrdered
und
StrictTotallyOrderedWith
Constraints) und ist vollständig in Bezug auf
ranges::less
definiert. Die Implementierung kann jedoch frei
operator
>
direkt verwenden, da diese Konzepte erfordern, dass die Ergebnisse der Vergleichsoperatoren konsistent sind.
Beispiel
|
Dieser Abschnitt ist unvollständig
Grund: Kein Beispiel |
Siehe auch
|
Funktionsobjekt, das
x
>
y
implementiert
(Klassentemplate) |