命名空间
变体
操作

std::partial_ordering

来自 cppreference.cn
< cpp‎ | 工具
 
 
 
定义于头文件 <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
[静态]
一个有效值,表示小于(排在前面)关系
(public static 成员常量)
inline constexpr std::partial_ordering equivalent
[静态]
一个表示等价的有效值(既不排在前面也不排在后面)
(public static 成员常量)
inline constexpr std::partial_ordering greater
[静态]
一个有效值,表示大于(排在后面)关系
(public static 成员常量)
inline constexpr std::partial_ordering unordered
[静态]
一个表示与不可比较值之间关系的有效值
(public static 成员常量)

[编辑] 转换

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) 如果 vless,则为 true;如果 vgreaterequivalentunordered,则为 false
2) 如果 vgreater,则为 true;如果 vlessequivalentunordered,则为 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) 如果 vlessequivalent,则为 true;如果 vgreaterunordered,则为 false
2) 如果 vgreaterequivalent,则为 true;如果 vlessunordered,则为 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) 如果 vgreater,则为 true;如果 vlessequivalentunordered,则为 false
2) 如果 vless,则为 true;如果 vgreaterequivalentunordered,则为 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) 如果 vgreaterequivalent,则为 true;如果 vlessunordered,则为 false
2) 如果 vlessequivalent,则为 true;如果 vgreaterunordered,则为 false

operator<=>

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

参数

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

返回值

1) v
2) 如果 vless,则为 greater;如果 vgreater,则为 less;否则为 v

[编辑] 备注

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

[编辑] 示例

[编辑] 参阅

支持所有6个操作符并且可替换的三路比较的结果类型
(class) [编辑]
支持所有6个操作符但不可替换的三路比较的结果类型
(class) [编辑]