c++运算符重载问题
所谓重载,就是重新赋予新的含义。函数重载是对一个已有的函数赋予新的含义,使之实现新功能。
其实运算符也可以重载,实际上,我们常常在不知不觉之中使用了运算符重载。
运算符重载的方法是定义一个重载运算符的函数,在需要执行被重载的运算符时,系统就自动调用该函数,以实现相应的运算。
也就是说,运算符重载是通过定义函数实现的。运算符重载实质上是函数的重载。
重载运算符的函数一般格式如下:
函数类型 operator 运算符名称(形参表列)
{
对运算符的重载处理
}
重载小规则1
C++不允许用户自己定义新的运算符,只能对已有的C++运算符进行重载。
除了一下五个运算符不允许重载外,其他运算符允许重载:
.(成员访问运算符)
.*(成员指针访问运算符)
::(域运算符)
sizeof(尺寸运算符)
?:(条件运算符)
重载小规则2
重载不能改变运算符运算对象(操作数)个数。
重载不能改变运算符的优先级别。
重载不能改变运算符的结合性。
重载运算符的函数不能有默认的参数。
重载的运算符必须和用户定义的自定义类型的对象一起使用,其参数至少应该有一个是类对象或类对象的引用。(也就是说,参数不能全部都是C++的标准类型,这样约定是为了防止用户修改用于标准类型结构的运算符性质)。
举个复数加法运算符重载的的栗子
实现复数加法
(3, 4i)+ (5, -10i)= (8, -6i)
#include <iostream>
// 演示对运算符"+"进行重载达到目的!
class Complex
{
public:
Complex();
Complex(double r, double i);
friend Complex operator+(Complex &c, Complex &d);
void print();
private:
double real;
double imag;
};
Complex::Complex()
{
real = 0;
imag = 0;
}
Complex::Complex(double r, double i)
{
real = r;
imag = i;
}
// 注意,这里作为友元函数,不属于Complex,记得别写 :: 咯!
Complex operator+(Complex &c, Complex &d)
{
return Complex(c.real+d.real, c.imag+d.imag);
}
void Complex::print()
{
std::cout << "(" << real