运算符重载允许为类或结构体重新定义+、-、==等运算符行为,使对象能像基本类型一样进行操作。

在C++中,运算符重载是一种允许我们为自定义类型(如类或结构体)重新定义已有运算符行为的机制。通过运算符重载,我们可以让对象像基本数据类型一样使用+、-、==、
1. 运算符重载的基本语法
运算符重载本质上是函数重载的一种形式,使用关键字 operator 后跟要重载的符号来定义函数。
基本语法如下:
返回类型 operator符号(参数列表) {
// 实现逻辑
}
例如,重载加法运算符:
立即学习“C++免费学习笔记(深入)”;
class Complex {
public:
double real, imag;
Complex(double r = 0, double i = 0) : real(r), imag(i) {}
// 成员函数方式重载 +
Complex operator+(const Complex& other) const {
return Complex(real + other.real, imag + other.imag);
}};
2. 成员函数 vs 友元函数重载
运算符可以作为成员函数或友元函数重载,选择取决于具体场景。
成员函数重载:
- 适用于左操作数是当前类对象的情况
- 隐含 this 指针作为第一个参数
- 适合重载 +=、-=、[]、()、= 等必须作为成员的运算符
友元函数重载:
- 可以访问类的私有成员
- 两个操作数都可以进行隐式转换
- 常用于重载 > 和对称性操作如 +、==
示例:用友元函数重载 }; std::ostream& operator
class Complex {
double real, imag;
public:
Complex(double r = 0, double i = 0) : real(r), imag(i) {}
friend std::ostream& operator<<(std::ostream& out, const Complex& c);
3. 常见可重载运算符示例
以下是一些常用运算符的重载方式:
赋值运算符 =
需要手动实现深拷贝,防止资源重复释放。
Complex& operator=(const Complex& other) {
if (this != &other) {
real = other.real;
imag = other.imag;
}
return *this;
}
比较运算符 ==
bool operator==(const Complex& other) const {
return real == other.real && imag == other.imag;
}
下标运算符 []
必须作为成员函数,常用于数组类封装。
int& operator[](int index) {
return data[index]; // 假设 data 是内部数组
}
4. 注意事项与限制
- 不能创建新的运算符,只能重载已有的(如不能定义 **)
- 以下运算符不能重载::: . .* ?: sizeof typeid alignof
- 重载后操作符的优先级和结合性不变
- 至少有一个操作数是用户定义类型
- 尽量保持语义一致性,避免滥用导致代码难懂
基本上就这些。掌握运算符重载能显著提升类的可用性和自然性,但应合理使用,避免过度“炫技”影响可维护性。











