C++20三向比较运算符(<=>)可自动生成全部六个比较运算符,支持默认实现(= default)或手动返回std::strong_ordering等类型,需确保成员可比较且operator==逻辑一致。

c++20的三向比较运算符(<=>)怎么用 一次性实现所有比较函数【新特性】

在 C++20 中,三向比较运算符(operator<=>),俗称“太空船运算符”(spaceship operator),能让你用一个函数**自动生成所有六个比较运算符**(==!=<<=>>=),大幅减少样板代码,还能保证语义一致性。

基本写法:声明并默认实现

最简单的方式是让编译器为你生成默认的三向比较:

例如:

struct Point {
  int x, y;
  auto operator<=>(const Point&) const = default;
};

这样,Point{1,2} == Point{1,2}Point{1,3} < Point{2,1} 等全部可用——编译器按成员顺序逐个比较,类似字典序。

手动实现:控制比较逻辑

当需要自定义比较行为(比如忽略大小写、按特定优先级排序),可以手动返回 std::strong_orderingstd::weak_orderingstd::partial_ordering

示例(字符串忽略大小写比较):

#include <string>
#include <charconv>
struct CaseInsensitiveString {
  std::string s;
  auto operator<=>(const CaseInsensitiveString& rhs) const {
    // 转小写后比较(简化示意,实际建议用 locale 或 std::tolower)
    std::string a = toLower(s), b = toLower(rhs.s);
    return a <=> b;
  }
private:
  static std::string toLower(const std::string& str) { /* ... */ }
};

与 operator== 的关系:注意一致性

C++20 规定:如果你显式定义了 operator<=>,且没写 operator==,编译器会自动生成一个基于 == 的默认 operator==(即调用 a <=> b == 0)。但若你同时写了 operator==,它**不会被覆盖**,也不会自动同步——这可能导致不一致。

注意事项和常见坑

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。