Namespaces
Variants

std:: compare_three_way_result

From cppreference.net
Utilities library
Определено в заголовке <compare>
template < class T, class U = T >
struct compare_three_way_result ;
(начиная с C++20)

Пусть t и u обозначают lvalue-выражения типов const std:: remove_reference_t < T > и const std:: remove_reference_t < U > соответственно. Если выражение t <=> u корректно, предоставляет член-тип type , равный decltype ( t <=> u ) , в противном случае член type отсутствует.

Если программа добавляет специализации для std::compare_three_way_result , поведение не определено.

Содержание

Типы членов

Название Определение
type тип результата operator <=> для const-квалифицированного lvalue типа T и U

Вспомогательные типы

template < class T, class U = T >
using compare_three_way_result_t = compare_three_way_result < T, U > :: type ;
(начиная с C++20)

Возможная реализация

// рекомендовано Кейси Картером
// см. также: https://github.com/microsoft/STL/pull/385#discussion_r357894054
template<class T, class U = T>
using compare_three_way_result_t = decltype(
    std::declval<const std::remove_reference_t<T>&>() <=>
    std::declval<const std::remove_reference_t<U>&>()
);
template<class T, class U = T>
struct compare_three_way_result {};
template<class T, class U>
    requires requires { typename compare_three_way_result_t<T, U>; }
struct compare_three_way_result<T, U>
{
    using type = compare_three_way_result_t<T, U>;
};

Пример

#include <compare>
#include <iostream>
#include <type_traits>
template<class Ord>
void print_cmp_type()
{
    if constexpr (std::is_same_v<Ord, std::strong_ordering>)
        std::cout << "strong ordering\n";
    else if constexpr (std::is_same_v<Ord, std::weak_ordering>)
        std::cout << "weak ordering\n";
    else if constexpr (std::is_same_v<Ord, std::partial_ordering>)
        std::cout << "partial ordering\n";
    else
        std::cout << "illegal comparison result type\n";
}
int main()
{
    print_cmp_type<std::compare_three_way_result_t<int>>();
    print_cmp_type<std::compare_three_way_result_t<double>>();
}

Вывод:

strong ordering
partial ordering

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

тип результата трёхстороннего сравнения, который поддерживает все 6 операторов, не является заменяемым и допускает несравнимые значения
(класс)
тип результата трёхстороннего сравнения, который поддерживает все 6 операторов и не является заменяемым
(класс)
тип результата трёхстороннего сравнения, который поддерживает все 6 операторов и является заменяемым
(класс)