std::compare_three_way_result
Von cppreference.com
| Definiert in der Header-Datei <compare> |
||
| template< class T, class U = T > struct compare_three_way_result; |
(seit C++20) | |
Seien t und u l-Werte von const std::remove_reference_t<T> bzw. const std::remove_reference_t<U>, falls der Ausdruck t <=> u wohlgeformt ist, stellt er den Member-Typedef type bereit, der gleich decltype(t <=> u) ist, andernfalls gibt es keinen Member type.
Wenn das Programm Spezialisierungen für std::compare_three_way_result hinzufügt, ist das Verhalten undefiniert.
Inhalt |
[bearbeiten] Member-Typen
| Name | Definition |
type
|
der Ergebnistyp von operator<=> für const-qualifizierte l-Werte von T und U |
[bearbeiten] Hilfstypen
| template< class T, class U = T > using compare_three_way_result_t = compare_three_way_result<T, U>::type; |
(seit C++20) | |
[bearbeiten] Mögliche Implementierung
// recommended by Casey Carter // see also: 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>; }; |
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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>>(); }
Ausgabe
strong ordering partial ordering
[bearbeiten] Siehe auch
| (C++20) |
der Ergebnistyp des 3-Wege-Vergleichs, der alle 6 Operatoren unterstützt, nicht substituierbar ist und unvergleichbare Werte zulässt (Klasse) |
| (C++20) |
der Ergebnistyp des 3-Wege-Vergleichs, der alle 6 Operatoren unterstützt und nicht substituierbar ist (Klasse) |
| (C++20) |
der Ergebnistyp des 3-Wege-Vergleichs, der alle 6 Operatoren unterstützt und substituierbar ist (Klasse) |