在前面的章节中我们已经接触过递增运算符的重载,那时候我们并没有区分前递增与后递增的差别,在通常情况下我们是分别不出++a与a++的差别的,但的确他们直接是存在明显差别的。
先看如下代码:
#include<iostream>
usingnamespacestd;
intmain()
{
inta=0;
++(++a);//正确,(++a)返回的是左值
(a++)++;//错误,(a++)返回的不是左值
system("pause");
}
代码中(a++)++编译出错误,返回“++”需要左值的错误,这正是前递增与后递增的差别导致的,那么又是为什么呢?
原因主要是由C++对递增(增量)运算符的定义引发的。
他们之间的差别主要为以下两点:
1、运算过程中,先将对象进行递增修改,而后返回该对象(其实就是对象的引用)的叫前递增(增量)运算。在运算符重载函数中采用返回对象引用的方式编写。
2、运算过程中,先返回原有对象的值,而后进行对象递增运算的叫后递增(增量)运算。在运算符重载函数中采用值返回的方式编写(这也正是前面(a++)++出错误的原因,(a++)返回的不是引用,不能当作左值继续参加扩号外部的++运算),重载函数的内部实现必须创建一个用于临时存储原有对象值的对象,函数返回的时候就是返回该临时对象。
那么在编写运算符重载函数的时候我们该如何区分前递增运算符重载函数与后递增运算符重载函数呢?
方法就是:在后递增运算符重载函数的参数中多加如一个int标识,标记为后递增运算符重载函数。
具体见如下实例(例一为非成员方式,例二为成员方式):
//例一
//程序作者:管宁
//站点:www.cndev-lab.com
//所有稿件均有版权,如要转载,请务必著名出处和作者
#include<iostream>
usingnamespacestd;
classTest
{
public:
Test(inta=0)
{
Test::a=a;
}
friendTest&operator++(Test&);
friendTestoperator++(Test&,int);
public:
inta;
};
Test&operator++(Test&temp)//前递增
{
temp.a++;
returntemp;
}
Testoperator++(Test&temp,int)//后递增,int在这里只起到区分作用,事实上并没有实际作用
{
Testrtemp(temp);//这里会调用拷贝构造函数进行对象的复制工作
temp.a++;
returnrtemp;
}
intmain()
{
Testa(100);
++(++a);
cout<<a.a<<endl;
cout<<"观察后递增情况下临时存储对象的值状态:"<<(a++).a<<endl;//这里正是体现后递增操作先返回原有对象值地方
cout<<a.a<<endl;
(a++)++;
cout<<a.a<<endl;//由于后递增是值返回状态,所以(a++)++只对a做了一次递增操作,操作后为104而非105。
system("pause");
}
//例二
//程序作者:管宁
//站点:www.cndev-lab.com
//所有稿件均有版权,如要转载,请务必著名出处和作者
#include<iostream>
usingnamespacestd;
classTest
{
public:
Test(inta=0)
{
Test::a=a;
}
Test&operator++();
Testoperator++(int);
public:
inta;
};
Test&Test::operator++()//前递增
{
this->a++;
return*this;
}
TestTest::operator++(int)//后递增
{
Testrtemp(*this);//这里会调用拷贝构造函数进行对象的复制工作
this->a++;
returnrtemp;
}
intmain()
{
Testa(100);
++(++a);
cout<<a.a<<endl;
cout<<"观察后递增情况下临时存储对象的值状态:"<<(a++).a<<endl;//这里正是体现后递增操作先返回原有对象值地方
cout<<a.a<<endl;
(a++)++;
cout<<a.a<<endl;//由于后递增是值返回状态,所以(a++)++只对a做了一次递增操作,操作后为104而非105。
system("pause");
}
通过对前后递增运算的分析,我们可以进一步可以了解到,对于相同情况的单目运算符重载我们都必须做好这些区别工作,保证重载后的运算符符合要求。
版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明!