超载的增量(++)和递减(——)算子都是很简单的,用一个小的例外。其实有递增和递减运算符有两个版本:一个前缀增量和减量(如+ NX;——纽约;)和一个后置递增和递减(如NX + +;纽约——;)。
因为递增和递减运算符修改其操作数,他们最好的重载成员函数。我们将采取前缀版本的第一次因为他们最直接的。
重载前缀增量和减量
前缀增量和减量是重载的完全一样,任何正常的一元运算符。我们将做到这一点的例子:|
class Digit
{
private:
int m_nDigit;
public:
Digit(int nDigit=0)
{
m_nDigit = nDigit;
}
Digit& operator++();
Digit& operator--();
int GetDigit() const { return m_nDigit; }
};
Digit& Digit::operator++()
{
// If our number is already at 9, wrap around to 0
if (m_nDigit == 9)
m_nDigit = 0;
// otherwise just increment to next number
else
++m_nDigit;
return *this;
}
Digit& Digit::operator--()
{
// If our number is already at 0, wrap around to 9
if (m_nDigit == 0)
m_nDigit = 9;
// otherwise just decrement to next number
else
--m_nDigit;
return *this;
}
我们的数字类包含0和9之间的数。我们已经超负荷的增加和减少他们的递增/递减的数字,如果数字环绕增大/减小幅度。
请注意,我们返回*this。重载的递增和递减运算符返回一个数字如此多的运营商可以“链接”在一起。因此,我们需要返回一个项目类型的数字。由于这些运算符作为成员函数的实现,我们可以返回*this,这是一项类型的数字!
重载后缀增量和减量
通常情况下,函数可以重载时,他们有相同的名字,但有不同的数量和/或不同类型的参数。然而,考虑的前缀和后缀递增和递减运算符的情况下。都具有相同的名称(如运算符++),都是一元,并以同一类型的参数。所以它是如何能够区分两个当超载?
答案是C + +中使用一个“虚拟变量”或“后缀式操作符的哑元”。这种说法是假的整数参数仅用于区分递增/递减后缀版本从前缀版。这里是两个前缀和后缀以上数字类的重载: