Namensräume
Varianten
Aktionen

std::compare_three_way

Von cppreference.com
< cpp‎ | utility
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
compare_three_way
(C++20)
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
Funktionsobjekte
Funktionsaufruf
(C++17)(C++23)
Identitätsfunktions-Objekt
(C++20)
Transparente Operator-Wrapper
(C++14)
(C++14)
(C++14)
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)

Alte Binder und Adaptoren
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
(bis C++17*)(bis C++17*)
(bis C++17*)(bis C++17*)

(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
 
Definiert in der Header-Datei <compare>
Definiert in der Header-Datei <functional>
struct compare_three_way;
(seit C++20)

Funktionsobjekt für Vergleiche. Leitet die Parametertypen und den Rückgabetyp des Funktionsaufrufoperators ab.

Inhalt

[bearbeiten] Verschachtelte Typen

Verschachtelter Typ Definition
is_transparent nicht spezifiziert

[bearbeiten] Memberfunktionen

operator()
Ermittelt das Ergebnis des Drei-Wege-Vergleichs beider Argumente
(öffentliche Memberfunktion)

std::compare_three_way::operator()

template< class T, class U >
constexpr auto operator()( T&& t, U&& u ) const;

Angesichts des Ausdrucks std::forward<T>(t) <=> std::forward<U>(u) als expr

  • Wenn die Konvertierungssequenz von T nach P oder die Konvertierungssequenz von U nach P nicht equality-preserving ist, ist das Verhalten undefiniert.
  • Andernfalls

Diese Überladung nimmt nur an der Overload-Auflösung teil, wenn std::three_way_comparable_with<T, U> erfüllt ist.

[bearbeiten] Beispiel

#include <compare>
#include <iostream>
 
struct Rational
{
    int num;
    int den; // > 0
 
    // Although the comparison X <=> Y will work, a direct call
    // to std::compare_three_way{}(X, Y) requires the operator==
    // be defined, to satisfy the std::three_way_comparable_with.
    constexpr bool operator==(Rational const&) const = default;
};
 
constexpr std::weak_ordering operator<=>(Rational lhs, Rational rhs)
{
    return lhs.num * rhs.den <=> rhs.num * lhs.den;
}
 
void print(std::weak_ordering value)
{
    value < 0 ? std::cout << "less\n" :
    value > 0 ? std::cout << "greater\n" :
                std::cout << "equal\n";
}
 
int main()
{
    Rational a{6, 5};
    Rational b{8, 7};
    print(a <=> b);
    print(std::compare_three_way{}(a, b));
}

Ausgabe

greater
greater

[bearbeiten] 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 3530 C++20 syntaktische Prüfungen wurden beim Vergleichen von Zeigern gelockert nur semantische Anforderungen sind gelockert

[bearbeiten] Siehe auch

Beschränktes Funktionsobjekt, das x == y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x != y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x < y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x > y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x <= y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x >= y implementiert
(Klasse) [edit]