Fork me on GitHub

c++之递增运算符重载

#include<iostream>
using namespace std;

class MyInteger {
    friend ostream& operator<<(ostream& cout, MyInteger myInteger);
public:
    MyInteger() {
        num = 0;
    }
    //重载++i运算符
    //返回引用是为了对同一个数据进行递增操作
    MyInteger & operator++() {
        num++;
        return *this;
    }
    //重载i++运算符,int是占位符,后置递增要返回值
    MyInteger operator++(int) {
        //先记录当时结果
        MyInteger tmp = *this;
        //后递增
        num++;
        //再返回记录的结果
        return tmp;
    }
private:
    int num;
};

ostream & operator<<(ostream &cout,MyInteger myInteger) {
    cout << "num=" << myInteger.num;
    return cout;
}
void test() {
    MyInteger myInteger;
    cout << ++(++myInteger)<<endl;
    cout << myInteger << endl;
}

void test2() {
    MyInteger myInteger;
    cout << myInteger++ << endl;
    cout << myInteger << endl;
}

int main() {
    test2();
    system("pause");
    return 0;
}

说明:

1.如果

 MyInteger & operator++() {
        num++;
        return *this;
    }

这里返回的是MyInteger而不是引用MyInteger &,在调用test()时,会输出:

 

也就是没有达到++i类似的效果:先计算,后赋值。这是因为,当执行一遍++MyInteger后,再执行++(++MyInteger) ,此时这里的(++MyInteger)已经不再是原来的MyInteger对象了,所以++(++MyInteger) 的结果是2,而MyInteger的结果是1,因此采用&,操作的就是同一个对象。这之后再调用test(),输出为:

 

要想实现另外一种自增,即i++,先赋值,后计算,就需要重载自增函数,只需要向重载函数中传入int占位符即可。同时,在函数里面,先要记录当前的值,再进行++,最后返回原先记录的值,这里返回的不能是引用,因为假设我们返回的是引用,相当于返回的是tmp的引用,而tmp是一个局部变量,在函数运行完后就会释放,此时再去访问该地址,就不合法了。最后调用test2(),输出为:

posted @ 2019-12-25 17:23  西西嘛呦  阅读(755)  评论(0编辑  收藏  举报