先定义一个测试类Complex,其中用成员函数的方法重载了+、-、前置++、前置--、后置++、后置--这6个运算符,当然,这6个操作符也可以用友元函数方式重载,但习惯上这些都直接用成员函数方式重载。
demo
#include
using namespace std;
class Complex
{
public:
Complex(int a = 0, int b = 0)
{
this->a = a;
this->b = b;
}
~Complex();
//打印复数
void printCom()
{
cout << a << " + " << b << "i" << endl;
}
// 实现 + 运算符重载
Complex operator+(Complex &c2)
{
Complex tmp(this->a + c2.a, this->b + c2.b);
return tmp;
}
// 实现 - 运算符重载
Complex operator-(Complex &c2)
{
Complex tmp(this->a - c2.a, this->b - c2.b);
return tmp;
}
// 实现 前置++ 运算符重载
Complex& operator++()
{
a++;
b++;
return *this;
}
// 实现 后置++ 运算符重载
// 这里涉及到了占位参数的使用,因为不过不用占位参数
// 后置++的重载函数和前置++的参数就相同了,这样重载就出现了语法错误
Complex& operator++(int)
{
Complex tmp = *this;
this->a++;
this->b++;
return tmp;
}
// 实现 前置-- 运算符重载
Complex& operator--()
{
a--;
b--;
return *this;
}
// 实现 后置-- 运算符重载
Complex& operator--(int)
{
Complex tmp = *this;
this->a--;
this->b--;
return tmp;
}
private:
int a;
int b;
};
int main()
{
return 0;
}
注意同时实现前置++和后置++时,成员函数重载时会出现参数相同而无法实现函数重载的情况,只需要给其中一个加上一个占位参数,就可以了。
1)友元函数和成员函数选择方法
当无法修改左操作数的类时,使用全局函数进行重载
=, [], ()和->操作符只能通过成员函数进行重载
2)用友元函数重载 << >>操作符
istream 和 ostream 是 C++ 的预定义流类
cin 是 istream 的对象,cout 是 ostream 的对象
运算符 << 由ostream 重载为插入操作,用于输出基本类型数据
运算符 >> 由 istream 重载为提取操作,用于输入基本类型数据
用友员函数重载 << 和 >> ,输出和输入用户自定义的数据类型
给第一个demo中的Complex类重载左移和右移操作符。
demo
// 友元函数方法实现 << 操作符重载
ostream& operator<<(ostream& out, Complex &c1)
{
out << c1.a << "+" << c1.b << "i" << endl;
return out;
}
// 友元函数方法实现 >> 操作符重载
istream& operator>>(istream& in, Complex &c1)
{
in >> c1.a >> c1.b;
return in;
}
记得要在类Complex中加上
friend ostream& operator<<(ostream& out, Complex &c1);
friend istream& operator>>(istream& in, Complex &c1);
这里就只能用友元函数做操作符重载了,因为如果用成员函数,必须要在操作符左边的数据类型的声明中加入代码,但是cout或者cin能获取到吗,就算获取到,这种做法也是及其不可取的,因为最好不要对自带库文件进行修改。所以这里最好的方式就是用友元函数。
3) 友元函数重载操作符使用注意点
a)友员函数重载运算符常用于运算符的左右操作数类型不同的情况。
b)其他
在第一个参数需要隐式转换的情形下,使用友员函数重载运算符是正确的选择。
友员函数没有 this 指针,所需操作数都必须在参数表显式声明,很容易实现类型的隐式转换。
C++中不能用友员函数重载的运算符有:
= () [] ->