Namespaces
Variants

std:: compare_weak_order_fallback

From cppreference.net
Utilities library
Definiert im Header <compare>
inline namespace /* unspecified */ {

inline constexpr /* unspecified */
compare_weak_order_fallback = /* unspecified */ ;

}
(seit C++20)
Aufrufsignatur
template < class T, class U >

requires /* siehe unten */
constexpr std:: weak_ordering

compare_weak_order_fallback ( T && t, U && u ) noexcept ( /* siehe unten */ ) ;
(seit C++20)

Führt einen Drei-Wege-Vergleich der Teilausdrücke t und u durch und erzeugt ein Ergebnis vom Typ std::weak_ordering , selbst wenn der Operator <=> nicht verfügbar ist.

Wenn std:: decay_t < T > und std:: decay_t < U > denselben Typ besitzen, std :: compare_weak_order_fallback ( t, u ) ist ausdrucksäquivalent zu:

  • std:: weak_order ( t, u ) , falls es ein wohlgeformter Ausdruck ist; andernfalls,
  • t == u ? std :: weak_ordering :: equivalent :
    t < u ? std :: weak_ordering :: less :
    std :: weak_ordering :: greater
    , falls die Ausdrücke t == u und t < u beide wohlgeformt sind und jeder von decltype ( t == u ) und decltype ( t < u ) das Konzept boolean-testable modelliert, mit der Ausnahme, dass t und u nur einmal ausgewertet werden.

In allen anderen Fällen ist std :: compare_weak_order_fallback ( t, u ) ill-formed, was zu Substitution Failure führen kann, wenn es im unmittelbaren Kontext einer Template-Instanziierung erscheint.

Inhaltsverzeichnis

Customization Point Objects

Der Name std::compare_weak_order_fallback bezeichnet ein Customization Point Object , welches ein konstantes Funktionsobjekt eines Literal semiregular Klassentyps ist. Weitere Details finden Sie unter CustomizationPointObject .

Beispiel

#include <compare>
#include <iostream>
// unterstützt kein <=>
struct Rational_1
{
    int num;
    int den; // > 0
};
inline constexpr bool operator<(Rational_1 lhs, Rational_1 rhs)
{
    return lhs.num * rhs.den < rhs.num * lhs.den;
}
inline constexpr bool operator==(Rational_1 lhs, Rational_1 rhs)
{
    return lhs.num * rhs.den == rhs.num * lhs.den;
}
// unterstützt <=>
struct Rational_2
{
    int num;
    int den; // > 0
};
inline constexpr std::weak_ordering operator<=>(Rational_2 lhs, Rational_2 rhs)
{
    return lhs.num * rhs.den <=> rhs.num * lhs.den;
}
inline constexpr bool operator==(Rational_2 lhs, Rational_2 rhs)
{
    return lhs <=> rhs == 0;
}
void print(int id, std::weak_ordering value)
{
    std::cout << id << ") ";
    if (value == 0)
        std::cout << "equal\n";
    else if (value < 0)
        std::cout << "less\n";
    else
        std::cout << "greater\n";
}
int main()
{
    Rational_1 a{1, 2}, b{3, 4};
//  print(0, a <=> b); // funktioniert nicht
    print(1, std::compare_weak_order_fallback(a, b)); // funktioniert, greift auf < und == zurück
    Rational_2 c{6, 5}, d{8, 7};
    print(2, c <=> d); // funktioniert
    print(3, std::compare_weak_order_fallback(c, d)); // funktioniert
    Rational_2 e{2, 3}, f{4, 6};
    print(4, e <=> f); // funktioniert
    print(5, std::compare_weak_order_fallback(e, f)); // funktioniert
}

Ausgabe:

1) less
2) greater
3) greater
4) equal
5) equal

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 2114
( P2167R3 )
C++20 der Fallback-Mechanismus verlangte nur,
dass Rückgabetypen zu bool konvertierbar sind
Einschränkungen verstärkt

Siehe auch

(C++20)
führt einen 3-Wege-Vergleich durch und erzeugt ein Ergebnis vom Typ std::weak_ordering
(Anpassungspunktobjekt)