今天在我更加深入地学习C++类的重载这一章,特别是读到有关重载自加运算符(++)的时候,我才发现我对C++的自增自减运算的了解并不很全面。以前只是机械的了解到所谓的前自加(++i)就是先加后用,后自加就是先用后加。这样就出现了很多我完全解释不通的地方,如下面的代码:

int main(){
    int i = 0;
    (i++) = 5; // 这里编译不通过: error: lvalue required as left operand of assignment
    cout << i << endl;
    i = 0;
    (++i) = 5;//而这里却可以编译通过,程序结果输出5。
    cout << i << endl;
    return 0;
}

为什么前自加可以作为左值,而后自加却不行?自从学习C++运算符重载这一章以后,我才对这个问题有了新的收获。在C++大学教程关于运算符重载这一章,我看到他是这样重载前自加和后自加的:

//以下代码是从C++大学教程第7版第11章运算符重载第13节研究实例:Data类中摘录的部分代码

Data& Data::operator++(){//重载前自加 helpIncremenet();//具体的自加操作,不是重点 return *this;//返回调用对象的引用 } const Data Data::operator++(int){//重载后自加运算 Data temp = *this;//保存调用对象 helpIncrement();//// return temp;//返回临时对象 }

从上面的代码可以看出,所谓前自加返回的进行自加运算后的对象引用,而后自加则返回的是执行自加运算前对象的一个临时变量。虽然一个是自定义的类类型,一个是C++内置类型,但是道理都是相通的。因此现在可以解释上面代码的问题了:(++i)运算完成后返回的是对 i加一后的引用,而(i++)运算完成后返回的却是一个临时变量并且该变量保存了i未进行加一前的数据。

读书还是不能不求甚解啊。

版权声明:本文为muzicangcang原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/muzicangcang/p/10543015.html