递增和递减运算符重载
在迭代器类中通常会实现递增运算符(++)和递减运算符(–),这两种运算符使得类可以在元素的序列中前后移动。
C++语言并不要求递增和递减运算符必须是类的成员,但是因为它们改变的正好是所操作对象的状态,所以建议将其设定为成员函数。对于内置类型来说,递增和递减运算符既有前置版本也有后置版本。同样,我们也应该为类定义两个版本的递增和递减运算符。接下来我们首先介绍前置版本,然后实现后置版本。
class Date
{
public:
Date(int year = 1900, int month = 1, int day = 1)
{
_year = year;
_month = month;
_day = day;
}
private:
int _year;
int _month;
int _day;
};
定义递增和递减运算符的类应该同时定义前置版本和后置版本。这些运算符通常应该被定义成类的成员。
定义前置递增/递减运算符
为了说明递增和递减运算符,我们不妨在 Date 类中定义它们:
class Date
{
public:
// 递增和递减运算符
Date& operator++() // 前置运算符
{
_day += 1;
return *this;
}
Date& operator--()
{
_day -= 1;
return *this;
}
// ...
};
注意:
前置++是返回+1之后的结果
this指向的对象函数结束后不会销毁,故以引用方式返回提高效率
区分前置和后置运算符
要想同时定义前置和后置运算符,必须首先解决一个问题,即普通的重载形式无法区分这两种情况。前置和后置版本使用的是同一个符号,意味着其重载版本所用的名字将是相同的,并且运算对象的数量和类型也相同。
为了解决这个问题,后置版本接受一个额外的(不被使用)int 类型的形参。当我们使用后置运算符时,编译器为这个形参提供一个值为0的实参。尽管从语法上来说后置函数可以使用这个额外的形参,但是在实际过程中通常不会这么做。这个形参的唯一作用就是区分前置版本和后置版本的函数,而不是真的要在实现后置版本时参与运算。
接下来我们为 Date 添加后置运算符:
class A
{
public:
// 递增和递减运算符
Date operator++(int) // 后置运算符
{
Date temp = *this;
_day += 1;
return temp;
}
Date operator--(int)
{
Date temp = *this;
_day -= 1;
return temp;
}
// ...
};
注意:
后置++是先使用,后+1,因此需要返回+1之前的旧值。
故需在实现时需要先将this保存一份,然后给this+1,而temp是临时对象,因此只能以值的方式返回,不能返回引用。