运算符重载为C++自定义类型赋予标准操作符新含义,如Complex类中重载+、=和

在C++中,运算符重载允许我们为自定义类型(如类或结构体)赋予标准运算符新的含义。这使得对象可以像基本数据类型一样使用 +、-、== 等操作符,提升代码可读性和自然性。但必须遵循一定的规则,避免滥用。
运算符重载的基本规则
运算符重载不是创建新运算符,而是为已有运算符提供针对用户自定义类型的实现方式。以下是关键规则:
- 只能重载C++已有的运算符,不能创建新符号
- 无法改变运算符的优先级和结合性
- 部分运算符必须作为类的成员函数重载(如 =、[]、()、->)
- 有些运算符推荐作为非成员函数实现(如 > 流操作符)
- 重载函数至少有一个参数是用户自定义类型
- 不能通过友元函数重载所有运算符,但可用于访问私有成员
常见运算符重载示例
以下是一个简单的复数类 Complex,演示如何重载加法、赋值和输出运算符。
// Complex.h class Complex { private: double real, imag; public: Complex(double r = 0, double i = 0) : real(r), imag(i) {} // 成员函数重载加法 Complex operator+(const Complex& other) const; // 成员函数重载赋值 Complex& operator=(const Complex& other); // 声明友元函数以重载输出 friend std::ostream& operator使用示例:
立即学习“C++免费学习笔记(深入)”;
int main() { Complex a(3, 4); Complex b(1, 2); Complex c = a + b; std::cout哪些运算符必须重载为成员函数?
以下运算符要求必须作为成员函数实现:
- =:赋值运算符
- []:下标访问
- ():函数调用
- ->:成员访问指针
这些需要直接操作对象内部状态,因此限定为成员函数形式。
流运算符为何常作为友元函数?
因为 和 >> 的第一个参数是 std::ostream& 或 std::istream&,不是自定义类本身。若强制作为成员函数,则需写成 c ,不符合习惯。
通过友元函数,既能保持自然语法 std::cout ,又能访问类的私有成员。
基本上就这些。掌握好边界,合理使用,能让类接口更直观。不复杂但容易忽略细节。比如记得处理自赋值、保持对称性、返回引用还是值等。按需选择成员或非成员实现方式即可。基本上就这些。










