std::compare_three_way

< cpp‎ | utility
 
 
工具库
语言支持
类型支持(基本类型、 RTTI 、类型特征)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
错误处理
协程支持 (C++20)
变参数函数
(C++17)
三路比较 (C++20)
compare_three_way
(C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++17)

初等字符串转换
(C++17)
(C++17)
 
定义于头文件 <compare>
定义于头文件 <functional>
struct compare_three_way;
(C++20 起)

进行比较的函数对象。从实参类型推导函数调用运算符的形参类型与返回类型。

成员类型

 
成员类型 定义
is_transparent /* 未指明 */

成员函数

operator()
获得两个参数上的三路比较结果
(公开成员函数)

std::compare_three_way::operator()

template<class T, class U>

    requires std::three_way_comparable_with<T, U> ||
             /* std::declval<T>() <=> std::declval<U>() 解析到比较指针的内建运算符 */

constexpr auto operator()(T&& t, U&& u) const;

比较 tu ,等价于 return std::forward<T>(t) <=> std::forward<U>(u); ,除非该表达式解析到调用比较指针的内建 operator<=>

当函数调用会使用比较 P 类型指针的内建运算符时,替而以下列方式确定结果:

  • 若第一参数的(可能为转换后的)值在 P 类型的所有指针值上的实现定义严格全序中前趋第二参数的(可能为转换后的)值,则返回 std::strong_ordering::less 。此严格全序与内建运算符 <><=>= 所施加的偏序一致。
  • 否则,若第二参数的(可能为转换后的)值在同一严格全序中前趋第一参数的(可能为转换后的)值,则返回 std::strong_ordering::greater
  • 否则返回 std::strong_ordering::equal

行为未定义,除非从 TUP 的转换序列均保持相等性(见后述)。

相等性保持

若表达式对给定的相等输入产生相等输出,则它保持相等性

  • 表达式的输入由其操作数组成。
  • 表达式的输出由其结果和表达式所修改的所有操作数(若存在)组成。

在标准概念的规范中,操作数定义为仅包含下列内容的最大子表达式:

每个操作数的 cv 限定与值类别,是通过假设每个模板类型形参代表一个 cv 无限定的非数组对象类型确定的。

进一步要求每个要求保持相等性的表达式都稳定:这种表达式带相同输入对象的二次求值必须拥有相等的输出,而无任何对这些输入对象的显式中间修改。

示例

#include <iostream>
#include <compare>
 
struct Rational_2 {
    int num;
    int den; // > 0
};
 
constexpr std::weak_ordering operator<=>(Rational_2 lhs, Rational_2 rhs)
{
    return lhs.num * rhs.den <=> rhs.num * lhs.den;
}
 
void print(std::weak_ordering value)
{
    if (value == 0)
        std::cout << "equal\n";
    else if (value < 0)
        std::cout << "less\n";
    else
        std::cout << "greater\n";
}
 
int main()
{
    Rational_2 c{6,5};
    Rational_2 d{8,7};
    print(c <=> d);
    print(std::compare_three_way{}(c,d));
}

输出:

greater
greater

参阅

实现 x == y 的函数对象
(类)
实现 x != y 的函数对象
(类)
实现 x < y 的函数对象
(类)
实现 x > y 的函数对象
(类)
实现 x <= y 的函数对象
(类)
实现 x >= y 的函数对象
(类)