进行顺序比较的优雅方法(C++)

Elegant way to do sequential comparison (C++)

本文关键字:方法 C++ 顺序 比较      更新时间:2023-10-16

假设我有一个包含多个成员变量的类:

class MyClass{
    std::string a;
    int b;
    SomeOtherClass c;
    // some stuff...
public:
    // some other stuff...
};

我想定义首先比较a的关系运算符(operator<等(,但如果a相等,则比较b,但如果b相等,则比较c。(我们假设SomeOtherClass已经定义了关系运算符。所以我有类似的东西

bool operator==(MyClass param){
    return (a == param.a) && (b == param.b) && (c == param.c);
}
bool operator<(MyClass param){
    if(a < param.a) return true;
    if(a > param.a) return false;
    if(b < param.b) return true;
    if(b > param.b) return false;
    if(c < param.c) return true;
    return false;
}

等等。有没有更优雅的方法可以做到这一点?这似乎很麻烦,特别是如果有很多成员变量需要比较。(增强是一种选择。

是的,我通常看到两种方式:

bool operator<(MyClass param){
    if(a != param.a) return a<param.a;
    if(b != param.b) return b<param.b;
    return c<param.c;
} 

http://coliru.stacked-crooked.com/view?id=dd70799c005e6e99c70ebda552161292-c96156d6cc95286981b0e9deef2eefae

bool operator<(MyClass param){
    return std::tie(a, b, c)<std::tie(param.a, param.b, param.c);
}

http://coliru.stacked-crooked.com/view?id=00278eaca0d73b099fcd8edf87b5057b-c96156d6cc95286981b0e9deef2eefae

当然,您可以使用std::tie

#include <tuple>
bool operator<(const MyClass& lhs, const MyClass& rhs)
{
  return std::tie(lhs.a, lhs.b, lhs.c) < std::tie(rhs.a, rhs.b, rhs.c);
}
当然

,您可以使用std::tie

#include <tuple>
bool operator<(MyClass param){
    return std::tie( a, b, c ) < std::tie( param.a, param.b, param.c );
}

它将创建一个tuple,之后,您只需使用 operator< .

此运算符将比较元组的每个元素。