重载自增与自减操作符

#include
#include 
using namespace std;

class CheckedPtr{
public:
        CheckedPtr(int *b,int *e):beg(b),end(e),curr(b){}/*无默认构造函数,需绑定某对象*/
        CheckedPtr& operator++();//前缀
          CheckedPtr& operator--();
        CheckedPtr operator++(int);//后缀
          CheckedPtr operator--(int);
//private:
        int *beg;
        int *end;
        int *curr;
};

CheckedPtr& CheckedPtr::operator++()
{
        if(curr==end)
                throw out_of_range("increment past the end of CheckedPtr");
        ++curr;
        return *this; 
}

CheckedPtr& CheckedPtr::operator--()
{
        if(curr==beg)
                throw out_of_range("decrement past the beginning of CheckedPtr");
        --curr;
        return *this;
}

CheckedPtr CheckedPtr::operator++(int)
{
        CheckedPtr ret(*this);
        ++*this;
        return ret;
}

CheckedPtr CheckedPtr::operator--(int)
{
        CheckedPtr ret(*this);
        --*this;
        return ret;
}

int main(){
        int a[5]={1,2,3,4,5};
        CheckedPtr parr(a,a+5);
        while(1)
        {
                cout<<*((++parr).curr)<

倾向于将自增自减重载作为类成员。为了与内置类型一致,前缀式的操作应返回被增量或减量对象的引用

同时定义前缀式操作符和后缀式操作符存在一个问题:它们的形参数目和类型相同,普通重载不能区别所定义的是前缀式操作符还是后缀式操作符。

为了解决这一问题,后缀式操作符函数接受一个额外的int型形参。使用后缀式操作符时,编译器提供0作为这个形参的实参。

为了与内置操作符一致,后缀式操作符应返回旧值(即,尚未自增或自减的值),并且,应作为值返回,而不是引用。


你可能感兴趣的:(C++)