重载递增运算符
递增运算符可以分为两种++a,a++,前置递增和后置递增,我们分别来实现,++一般写在成员函数里面
前置++
成员函数实现:
#include <iostream>
using namespace std;
class person
{
public:
person operator++()
{
++this->m_a;
++this->m_b;
return *this;
}
person()
{
m_a = 10;
m_b = 20;
}
person(int a, int b) :m_a(a), m_b(b)
{
}
person(const person& p)
{
m_a = p.m_a;
m_b = p.m_b;
}
int m_a;
int m_b;
};
int main()
{
person p;
++(++p);
cout << p.m_a << endl;
}
我们注意一个问题,这段代码输出是11,但是我们进行了两次++:++(++p),为什么是这样的?
问题出现在这个位置:
我们返回的不是引用,返回的是一份值的拷贝,所以我们的第二次加加相当于加在了那份拷贝上面。
所以我们应该写成:person & operator++()
后置递增运算 a++
先不看返回值类型,这个时候就要用到我们的占位参数了,也可以理解为占位参数是用来区分前置++和后置++的符号:
后置运算符就是先返回再加一,那我们是这样写吗?
显然是不对的,这里return在前面。所以我们必须改变者这种写法
正确的写法:
这幅图片和前置加加有一个很重要的区别,那就是返回的类型是person而不是person&?
这个位置返回的是一个temp,是一个临时变量,不能返回临时变量的引用!因为结束后就会释放临时变量。