std::compare_three_way_result
From cppreference.com
| ヘッダ <compare> で定義 |
||
| template< class T, class U = T > struct compare_three_way_result; |
(C++20以降) | |
t と u を、それぞれ const std::remove_reference_t<T> および const std::remove_reference_t<U> の左辺値とします。式 t <=> u が well-formed である場合、メンバ型エイリアス type を decltype(t <=> u) に等しいものとして提供します。そうでない場合は、メンバ type は存在しません。
プログラムが std::compare_three_way_result の特殊化を追加した場合、その動作は未定義です。
目次 |
[編集] メンバ型
| 名前 | 定義 |
type
|
T および U の const 修飾された左辺値に対する operator<=> の結果の型 |
[編集] ヘルパー型
| template< class T, class U = T > using compare_three_way_result_t = compare_three_way_result<T, U>::type; |
(C++20以降) | |
[編集] 実装例
// 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>; }; |
[編集] 例
このコードを実行
#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
[編集] 関連項目
| (C++20) |
6つすべての演算子をサポートし、置換可能ではなく、比較不可能な値を許容する三方比較の結果型 (クラス) |
| (C++20) |
6つすべての演算子をサポートし、置換可能ではない三方比較の結果型 (クラス) |
| (C++20) |
6つすべての演算子をサポートし、置換可能である三方比較の結果型 (クラス) |