通行证:用户名 密码 首页 - 新闻 - 免费邮箱 - 短信 - POPO - 相册 - 搜索 - 交友 - 拍卖
NetEase
新闻 | 体育 | 财经 | 娱乐 | 商业 | 科技 | 汽车 | 数码 | 女人 | 旅游 | 教育 | 文化 | 广州 | 军事 | 部落
评论 | NBA | 明星 | 证券 | 基金 | 探索 | 房产 | 手机 | 两性 | 健康 | 培训 | 电影 | 游戏 | 拍卖 | 论坛
你现在的位置是: 网易 > 网易科技 > 网易学院·教程

对C++递增(增量)运算符重载的思考

http://tech.163.com/school · 2005-04-14 11:01:17 · 来源: 网易学院

  在前面的章节中我们已经接触过递增运算符的重载,那时候我们并没有区分前递增与后递增的差别,在通常情况下我们是分别不出++a与a++的差别的,但的确他们直接是存在明显差别的。

  先看如下代码:

 C++ 代码 
#include <iostream>   
using namespace std;   
   
int main()   
{   
    int a=0; 
    ++(++a);//正确,(++a)返回的是左值 
    (a++)++;//错误,(a++)返回的不是左值 
    system("pause"); 
}


  代码中(a++)++编译出错误,返回“++”需要左值的错误,这正是前递增与后递增的差别导致的,那么又是为什么呢?

  原因主要是由C++对递增(增量)运算符的定义引发的。

他们之间的差别主要为以下两点:

1.运算过程中,先将对象进行递增修改,而后返回该对象(其实就是对象的引用)的叫前递增(增量)运算。在运算符重载函数中采用返回对象引用的方式编写。

2.运算过程中,先返回原有对象的值,而后进行对象递增运算的叫后递增(增量)运算。在运算符重载函数中采用值返回的方式编写(这也正是前面(a++)++出错误的原因,(a++)返回的不是引用,不能当作左值继续参加扩号外部的++运算),重载函数的内部实现必须创建一个用于临时存储原有对象值的对象,函数返回的时候就是返回该临时对象。

  那么在编写运算符重载函数的时候我们该如何区分前递增运算符重载函数与后递增运算符重载函数呢?

  方法就是:在后递增运算符重载函数的参数中多加如一个int标识,标记为后递增运算符重载函数。


具体见如下实例(例一为非成员方式,例二为成员方式):


 C++ 代码 
//例一 
 
//程序作者:管宁         
//站点:www.cndev-lab.com         
//所有稿件均有版权,如要转载,请务必著名出处和作者      
   
#include <iostream>   
using namespace std;   
   
class Test     
{     
    public:     
        Test(int a=0) 
        { 
            Test::a = a; 
        } 
    friend Test& operator ++ (Test&); 
    friend Test operator ++ (Test&,int); 
    public
    int a; 
}; 
Test& operator ++ (Test &temp)//前递增 

    temp.a++; 
    return temp; 

Test operator ++ (Test &temp,int)//后递增,int在这里只起到区分作用,事实上并没有实际作用 

    Test rtemp(temp);//这里会调用拷贝构造函数进行对象的复制工作 
    temp.a++; 
    return rtemp; 

int main() 

    Test a(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"); 
}



 C++ 代码 
//例二 
 
//程序作者:管宁         
//站点:www.cndev-lab.com         
//所有稿件均有版权,如要转载,请务必著名出处和作者      
   
#include <iostream>   
using namespace std;   
   
class Test     
{     
    public:     
        Test(int a=0) 
        { 
            Test::a = a; 
        } 
    Test& operator ++ (); 
    Test operator ++ (int); 
    public
    int a; 
}; 
Test& Test::operator ++ ()//前递增 

    this->a++; 
    return *this

Test Test::operator ++ (int)//后递增 

    Test rtemp(*this);//这里会调用拷贝构造函数进行对象的复制工作 
 
    this->a++; 
    return rtemp; 

int main() 

    Test a(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"); 
}


  通过对前后递增运算的分析,我们可以进一步可以了解到,对于相同情况的单目运算符重载我们都必须做好这些区别工作,保证重载后的运算符符合要求。

落叶秋客 [返回首页]

相关文章:

推荐文章:

·赢在2007赛迪网年度企业人物榜单揭晓 ·你最需要哪种类型的视频教程 ·不用网银也网上购物 三步自助开通 ·2007年UPA用户体验大会成功闭幕 ·2007中国青年设计节暨用户体验年会在京开幕 ·User Friendly 2007现场图片 ·手机畅游互联网 空中Opera 2.0实测 ·动易软件即将全面开源和免费 ·搜图有“道” 图片达人的搜索秘籍 ·数字水墙 08年世博会亮相 ·RabbitAir MinusA2空气净化器设计 ·Oscar Bjarnason 平面设计 ·国产杀毒软件半个月内勇夺两项国际权威认证 ·美化你的博客-推荐多个博客图标下载网站 ·微软回应Vista用户遇到的网络问题“设计如此” ·eBay改进用户体验 借鉴亚马逊页面设计搜索功能 ·极点五笔6.0正式版发布 ·WPS Office 2007抢先试用 ·报告称Google Apps功能远不及微软Office ·什么是SOCK5代理,什么是HTTP代理

最新评论
  更多评论 0 条评论
网易通行证:   密码:    
参与评论
  您的发表的评论将在5分钟内被审核,请耐心等待

网易学院联系电话:020-61210163-560 合作/投稿邮箱:NeteaseSchool(at)126.com