命名空间
变体
操作

std::partial_ordering

来自 cppreference.cn
< cpp‎ | utility
 
 
 
定义于头文件 <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 static 数据成员

名称 定义
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, /*未指定*/ 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, /*未指定*/ u ) noexcept;
(1)
friend constexpr bool operator<( /*未指定*/ u, partial_ordering v ) noexcept;
(2)

参数

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

返回值

1)vless,则为 true;若 vgreaterequivalentunordered,则为 false
2)vgreater,则为 true;若 vlessequivalentunordered,则为 false

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)vlessequivalent,则为 true;若 vgreaterunordered,则为 false
2)vgreaterequivalent,则为 true;若 vlessunordered,则为 false

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)vgreater,则为 true;若 vlessequivalentunordered,则为 false
2)vless,则为 true;若 vgreaterequivalentunordered,则为 false

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)vgreaterequivalent,则为 true;若 vlessunordered,则为 false
2)vlessequivalent,则为 true;若 vgreaterunordered,则为 false

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)vless,则为 greater;若 vgreater,则为 less;否则为 v

[编辑] 注解

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

[编辑] 示例

[编辑] 参见

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