Namespaces
Variants

std:: compare_weak_order_fallback

From cppreference.net
Utilities library
Определено в заголовочном файле <compare>
inline namespace /* unspecified */ {

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

}
(начиная с C++20)
Сигнатура вызова
template < class T, class U >

requires /* see below */
constexpr std:: weak_ordering

compare_weak_order_fallback ( T && t, U && u ) noexcept ( /* see below */ ) ;
(начиная с C++20)

Выполняет трёхстороннее сравнение подвыражений t и u и возвращает результат типа std::weak_ordering , даже если оператор <=> недоступен.

Если std:: decay_t < T > и std:: decay_t < U > являются одним и тем же типом, std :: compare_weak_order_fallback ( t, u ) является эквивалентным по выражению следующему:

  • std:: weak_order ( t, u ) , если это корректное выражение; в противном случае,
  • t == u ? std :: weak_ordering :: equivalent :
    t < u ? std :: weak_ordering :: less :
    std :: weak_ordering :: greater
    , если выражения t == u и t < u являются корректными и каждый из decltype ( t == u ) и decltype ( t < u ) моделирует boolean-testable , за исключением того, что t и u вычисляются только один раз.

Во всех остальных случаях std :: compare_weak_order_fallback ( t, u ) является некорректно сформированным, что может привести к ошибке подстановки когда оно появляется в непосредственном контексте инстанцирования шаблона.

Содержание

Объекты точек кастомизации

Имя std::compare_weak_order_fallback обозначает объект точки кастомизации , который является константным функциональным объектом типа литерального semiregular класса. Для подробностей см. CustomizationPointObject .

Пример

#include <compare>
#include <iostream>
// не поддерживает <=>
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;
}
// поддерживает <=>
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); // не работает
    print(1, std::compare_weak_order_fallback(a, b)); // работает, использует < и == по умолчанию
    Rational_2 c{6, 5}, d{8, 7};
    print(2, c <=> d); // работает
    print(3, std::compare_weak_order_fallback(c, d)); // работает
    Rational_2 e{2, 3}, f{4, 6};
    print(4, e <=> f); // работает
    print(5, std::compare_weak_order_fallback(e, f)); // работает
}

Вывод:

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

Отчеты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Применяется к Поведение в опубликованной версии Корректное поведение
LWG 2114
( P2167R3 )
C++20 механизм отката требовал только
чтобы возвращаемые типы были конвертируемы в bool
ограничения усилены

Смотрите также

(C++20)
выполняет трёхстороннее сравнение и возвращает результат типа std::weak_ordering
(объект точки кастомизации)