用于前增量和后增量的重载++

2022-02-27 00:00:00 operator-overloading c++

我们可以为增量前和增量后重载operator++吗?即调用SampleObject++++SampleObject结果正确。

class CSample {
 public:
   int m_iValue;     // just to directly fetch inside main()
   CSample() : m_iValue(0) {}
   CSample(int val) : m_iValue(val) {}
   // Overloading ++ for Pre-Increment
   int /*CSample& */ operator++() { // can also adopt to return CSample&
      ++(*this).m_iValue;
      return m_iValue; /*(*this); */
   }

  // Overloading ++ for Post-Increment
 /* int operator++() {
        CSample temp = *this;
        ++(*this).m_iValue;
        return temp.m_iValue; /* temp; */
    } */
};

我们不能仅根据返回类型重载函数,而且即使我们认为它是允许的,也不能解决问题,因为重载解析中存在歧义。

既然提供了运算符重载,以使内置类型的行为类似于用户定义的类型,为什么我们自己的类型不能同时使用前增量和后增量呢?


解决方案

增量运算符的后缀版本采用伪参数int以消除歧义:

// prefix
CSample& operator++()
{
  // implement increment logic on this instance, return reference to it.
  return *this;
}

// postfix
CSample operator++(int)
{
  CSample tmp(*this);
  operator++(); // prefix-increment this instance
  return tmp;   // return value before increment
}

相关文章