在c++中,函数重载也称为函数多态,运算符重载是一种形式的c++多态。运算符重载将重载的概念扩展到运算符上,允许赋予c++运算符多种含义。例如*运算符用于地址,将得到存储在这个地址中的值,但将它用于两个数字时,得到的将是它们的乘积。此时,c++根据操作数的数目和类型来决定采用哪种操作。
C++允许将运算符重载扩展到用户定义的类型,如对象。要重载运算符,需使用被称为运算符函数的特殊函数形式。运算符函数的格式如下:operatorop(参数列表),其中op为运算符。如operator+(),重载+运算符。
c++也对运算符重载做出了限制:
- 重载后的运算符必须至少有一个操作数是用户自定义类型,防止用户为标准类型重载运算符,例如不能用-运算符重载计算两个double值的和。
- 使用运算符不能违反运算符原来的句法规则,如不能用%求模运算符作用于一个操作数;也不能修改运算符的优先级,重载后运算符与标准类型运算符有着相同的优先级。
- 不能创建新运算符
- 不能重载以下运算符:sizeof,.成员运算符,.*成员指针运算符,::作用域解析运算符,?:条件运算符,typeid和一些强制类型转换运算符。
大都数运算符都可通过成员函数或非成员函数(友元函数)重载,但存在以下运算符只能通过成员函数重载:=赋值运算符,()函数调用运算符,[]下标运算符,->通过指针访问类成员运算符。
// +重载示例
class Time{
private:
int hours;
int minutes;
public: // 成员函数使用内联函数
Time(int _hours = 0, int _minutes = 0){
hours = _hours;
minutes = _minutes;
}
Time operator+(const Time &t)const{ // 重载+,const用于无法修改调用对象
Time res;
res.minutes = minutes + t.minutes;
res.hours = hours + t.hours + res.minutes/60;
res.minutes %= 60;
return res;
}
void show()const{
std::cout << hours << "hours," << minutes << "minutes" << std::endl;
}
};
int main()
{
Time t1(6,45);
Time t2(3,15);
Time t3 = t1 + t2; // 1)处
t3.show();
return 0; // 调用默认析构函数
}
// 示例输出结果
10hours,0minutes
1):Time t3 = t1 + t2;的实质是Time t3 = t1.operator+(t2);,也是另一种写法。注意:+运算符左侧是调用对象,右侧是作为参数被传递的对象。例如:t4 = t1 + t2 + t3;在定义后都是合法的,operater+()返回的是Time对象,t4 = t1 + t2 + t3;会被转换为t4 = t1.operator+(t2.operator+(t3));。