std::experimental::ranges:: not_equal_to
|
Definiert im Header
<experimental/ranges/functional>
|
||
|
template
<
class
T
=
void
>
requires EqualityComparable
<
T
>
||
|
(ranges TS) | |
|
template
<>
struct not_equal_to < void > ; |
(ranges TS) | |
Funktionsobjekt zum Durchführen von Vergleichen. Die primäre Vorlage ruft
operator
==
auf const Lvalues vom Typ
T
auf und negiert das Ergebnis. Die Spezialisierung
not_equal_to<void>
leitet die Parametertypen des Funktionsaufrufoperators aus den Argumenten ab (aber nicht den Rückgabetyp).
Alle Spezialisierungen von
not_equal_to
sind
Semiregular
.
Inhaltsverzeichnis |
Mitgliedertypen
| Mitgliedtyp | Definition |
is_transparent
(nur Mitglied der
not_equal_to<void>
Spezialisierung)
|
/* nicht spezifiziert */ |
Memberfunktionen
|
operator()
|
prüft, ob die Argumente
nicht gleich sind
(öffentliche Elementfunktion) |
std::experimental::ranges::not_equal_to:: operator()
|
constexpr
bool
operator
(
)
(
const
T
&
x,
const
T
&
y
)
const
;
|
(1) |
(nur Mitglied der primären
not_equal_to<T>
-Vorlage)
|
|
template
<
class
T,
class
U
>
requires EqualityComparableWith
<
T, U
>
||
|
(2) |
(nur Mitglied der
not_equal_to<void>
-Spezialisierung)
|
t
und
u
. Entspricht
return
!
ranges::
equal_to
<>
{
}
(
std::
forward
<
T
>
(
t
)
,
std::
forward
<
U
>
(
u
)
)
;
.
Hinweise
Im Gegensatz zu
std::not_equal_to
erfordert
ranges::not_equal_to
, dass sowohl
==
als auch
!=
gültig sind (über die
EqualityComparable
- und
EqualityComparableWith
-Constraints) und ist vollständig in Bezug auf
ranges::equal_to
definiert. Allerdings ist die Implementierung frei,
operator
!
=
direkt zu verwenden, da diese Konzepte erfordern, dass die Ergebnisse von
==
und
!=
konsistent sind.
Beispiel
|
Dieser Abschnitt ist unvollständig
Grund: Kein Beispiel |
Siehe auch
|
Funktionsobjekt, das
x
!
=
y
implementiert
(Klassen-Template) |