命名空间
变体
操作

std::partial_ordering

来自 cppreference.com
< cpp‎ | utility
 
 
实用程序库
语言支持
类型支持 (基本类型,RTTI)
库功能测试宏 (C++20)
动态内存管理
程序实用程序
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三元比较
partial_ordering
(C++20)
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用实用程序
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
通用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
基本字符串转换
(C++17)
(C++17)

 
定义在头文件 <compare>
class partial_ordering;
(自 C++20 起)

类类型 std::partial_ordering三元比较 的结果类型,其

  • 允许所有六个关系运算符 (==, !=, <, <=, >, >=)。
  • 不意味着可替换性:如果 a 等价于 b,则 f(a) 可能不等价于 f(b),其中 f 表示仅读取通过参数的公共 const 成员访问的与比较相关的状态的函数。换句话说,等价的值可能是可区分的。
  • 允许不可比的值a < ba == ba > b 都可能为 false

内容

[编辑] 常量

类型 std::partial_ordering 有四个有效值,以其类型的 const 静态数据成员形式实现

名称 定义
inline constexpr std::partial_ordering less
[静态]
一个有效值,指示小于(在之前排序)关系
(公共静态成员常量)
inline constexpr std::partial_ordering equivalent
[静态]
一个有效值,指示等价(既不在之前排序也不在之后排序)关系
(公共静态成员常量)
inline constexpr std::partial_ordering greater
[静态]
一个有效值,指示大于(在之后排序)关系
(公共静态成员常量)
inline constexpr std::partial_ordering unordered
[静态]
一个有效值,指示与不可比的值的关系
(公共静态成员常量)

[编辑] 转换

std::partial_ordering 不能隐式转换为其他比较类别类型,而 std::strong_orderingstd::weak_ordering 都可以隐式转换为 partial_ordering

[编辑] 比较

比较运算符在该类型的值和字面量 0 之间定义。这支持表达式 a <=> b == 0a <=> b < 0,可用于将三元比较运算符的结果转换为布尔关系;请参阅 std::is_eqstd::is_lt 等。

这些函数对普通的 非限定限定查找 不可見,只能在 std::partial_ordering 是参数的关联类时,通过 参数相关查找 找到。

尝试将 partial_ordering 与除整数字面量 0 以外的任何内容进行比较的程序的行为是未定义的。

operator==operator<operator>operator<=operator>=operator<=>
与零或 partial_ordering 进行比较
(函数)

operator==

friend constexpr bool operator==( partial_ordering v, /*unspecified*/ u ) noexcept;
(1)
friend constexpr bool
    operator==( partial_ordering v, partial_ordering w ) noexcept = default;
(2)

参数

v, w - 要检查的 std::partial_ordering
u - 任何类型(接受字面量零参数)的未使用参数

返回值

1) 如果 vequivalent,则为 true;如果 vlessgreaterunordered,则为 false
2) 如果两个参数都持有相同的值,则为 true;否则为 false

operator<

friend constexpr bool operator<( partial_ordering v, /*unspecified*/ u ) noexcept;
(1)
friend constexpr bool operator<( /*unspecified*/ u, partial_ordering v ) noexcept;
(2)

参数

v - 要检查的 std::partial_ordering
u - 任何类型(接受字面量零参数)的未使用参数

返回值

1) true 如果 vless, 且 false 如果 vgreaterequivalentunordered
2) true 如果 vgreater, 且 false 如果 vlessequivalentunordered

operator<=

friend constexpr bool operator<=( partial_ordering v, /*未指定*/ u ) noexcept;
(1)
friend constexpr bool operator<=( /*未指定*/ u, partial_ordering v ) noexcept;
(2)

参数

v - 要检查的 std::partial_ordering
u - 任何类型(接受字面量零参数)的未使用参数

返回值

1) true 如果 vlessequivalent, 且 false 如果 vgreaterunordered
2) true 如果 vgreaterequivalent, 且 false 如果 vlessunordered

operator>

friend constexpr bool operator>( partial_ordering v, /*未指定*/ u ) noexcept;
(1)
friend constexpr bool operator>( /*未指定*/ u, partial_ordering v ) noexcept;
(2)

参数

v - 要检查的 std::partial_ordering
u - 任何类型(接受字面量零参数)的未使用参数

返回值

1) true 如果 vgreater, 且 false 如果 vlessequivalentunordered
2) true 如果 vless, 且 false 如果 vgreaterequivalentunordered

operator>=

friend constexpr bool operator>=( partial_ordering v, /*未指定*/ u ) noexcept;
(1)
friend constexpr bool operator>=( /*未指定*/ u, partial_ordering v ) noexcept;
(2)

参数

v - 要检查的 std::partial_ordering
u - 任何类型(接受字面量零参数)的未使用参数

返回值

1) true 如果 vgreaterequivalent, 且 false 如果 vlessunordered
2) true 如果 vlessequivalent, 且 false 如果 vgreaterunordered

operator<=>

friend constexpr partial_ordering operator<=>( partial_ordering v, /*未指定*/ u ) noexcept;
(1)
friend constexpr partial_ordering operator<=>( /*未指定*/ u, partial_ordering v ) noexcept;
(2)

参数

v - 要检查的 std::partial_ordering
u - 任何类型(接受字面量零参数)的未使用参数

返回值

1) v.
2) greater 如果 vlessless 如果 vgreater, 否则 v.

[编辑] 备注

浮点数之间的 内置 operator<=> 使用此排序:正零和负零比较 equivalent,但可以区分,NaN 值与任何其他值比较 unordered

[编辑] 示例

[编辑] 另请参阅

支持所有 6 个运算符且可替代的 3 路比较结果类型
(类) [编辑]
支持所有 6 个运算符且不可替代的 3 路比较结果类型
(类) [编辑]