std:: compare_weak_order_fallback
|
Определено в заголовочном файле
<compare>
|
||
|
inline
namespace
/* unspecified */
{
inline
constexpr
/* unspecified */
|
(начиная с C++20) | |
|
Сигнатура вызова
|
||
|
template
<
class
T,
class
U
>
requires
/* 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
(объект точки кастомизации) |