运算符重载基础&复数的重载&模板形参中传递函数指针
我们之前学习了C++的函数重载,但是不止函数可以重载,运算符也是可以重载的,运算符重载主要应用于对象,因为一般数据结构间的运算符没有重载的必要性。
运算符重载后,原有的基本语义不变,但是有几点需要注意:
- 不会改变运算符的优先级
- 不会改变运算符的结合性
- 不会改变运算符所需要的操作数的个数
- 不会改变运算符的原有的语法结构
- 不能重载的运算符:“.”,“.*”,“::”,“?:”,“sizeof”
我们在进行对象之间的运算的时候,编译器会自动调用运算符相应的函数进行处理,所以运算符重载有两种方式:成员函数和友元函数。
两者区别:
- 成员函数由于遵守_thiscall调用约定,所以有一个隐藏的this指针,所以我们传入的参数个数会少一个。
- 友元函数由于由于不遵循_thiscall调用约定,所以没有隐含的this指针。这样,对于双目运算符来说,友元函数有2个参数,对于单目运算符来说,友元函数只有一个参数。
- 注意:有些运算符不能重载为友元函数,比如:“=”,“()”,“[]”,“->”
一:我们这里主要看一看常用的运算符重载
(1)一般运算符重载
例如加减乘除四则运算运算符的重载:
代码如下:
#include <iostream>
class Test
{
public:
Test(int a):ma(a){}
Test operator+(const Test& rhs);//成员函数形式
Test operator-(const Test& rhs);
Test operator*(const Test& rhs);
Test operator/(const Test& rhs);
friend Test operator+(Test& rhs1, Test& rhs2);//友元函数形式
friend Test operator-(Test& rhs1, Test& rhs2);
friend Test operator*(Test& rhs1, Test& rhs2);
friend Test operator/(Test& rhs1, Test& rhs2);
void show()
{
std::cout << ma << std::endl;
}
private:
int ma;
};
Test Test::operator+(const Test& rhs)//成员函数形式
{
return Test(ma + rhs.ma);
}
Test Test::operator-(const Test& rhs)
{
return Test(ma - rhs.ma);
}
Test Test::operator*(const Test& rhs)
{
return Test(ma * rhs.ma);
}
Test Test::operator/(const Test& rhs)
{
return Test(ma / rhs.ma);
}
Test operator+(Test& rhs1, Test& rhs2)//友元函数形式
{
return Test(rhs1.ma + rhs2.ma);
}
Test operator-(Test& rhs1, Test& rhs2)
{
return Test(rhs1.ma - rhs2.ma);
}
Test operator*(Test& rhs1, Test& rhs2)
{
return Test(rhs1.ma * rhs2.ma);
}
Test operator/