浅析C++中临时匿名对象

来源:互联网 发布:lua调用java 编辑:程序博客网 时间:2024/06/03 13:25

首先先看代码:

[cpp] view plaincopy在CODE上查看代码片派生到我的代码片
  1. #include <iostream>  
  2.   
  3. using namespace std;  
  4.   
  5. /* 
  6.     类名:A 
  7. */  
  8. class A  
  9. {  
  10.     int num;  
  11. public:  
  12.     A( int num );  
  13.     ~A();  
  14.     A( A& a );  
  15.     A operator=( int num );  
  16.     friend ostream& operator<<( ostream& o, const A& a );  
  17. };  
  18. /*  
  19.     A类的构造函数  
  20. */  
  21. A::A( int num ):num(num)  
  22. {   
  23.     cout << "Constructor is Called..." << "\t,addr = " << this << endl;   
  24. }  
  25. /*  
  26.     A类的析构函数  
  27. */  
  28. A::~A()  
  29. {  
  30.     cout << "Destructor is Called..." << "\t,addr = " << this << endl;   
  31. }  
  32. /*  
  33.     类A重载=运算符  
  34. */  
  35. A A::operator=( int num )  
  36. {  
  37.     cout << "operator= is Called..." << "\t\t,addr = " << this << endl;   
  38.     return A(num);  
  39. }  
  40. /* 
  41.     类A重载<<运算符 
  42. */  
  43. ostream& operator<<( ostream& o, const A& a )  
  44. {  
  45.     o << a.num;  
  46.     return o;  
  47. }  
  48. /* 
  49.     入口函数 
  50. */  
  51. int main()  
  52. {  
  53.     A a(10);  
  54.     A b = (a = 20);  
  55.     cout << "================================================" << endl;  
  56.     cout << "a = " << a << "\t,addr = " << &a << endl;  
  57.     cout << "b = " << b << "\t,addr = " << &b << endl;  
  58.     cout << "================================================" << endl;  
  59. }  
输出结果:

Constructor is Called...    ,addr = 0027FC90
operator= is Called...        ,addr = 0027FC90
Constructor is Called...    ,addr = 0027FC84
================================================
a = 10    ,addr = 0027FC90
b = 20    ,addr = 0027FC84
================================================
Destructor is Called...    ,addr = 0027FC84
Destructor is Called...    ,addr = 0027FC90
这里主要浅析两个问题:
  1.非引用返回临时匿名对象
  2.临时匿名对象的析构
分析:

  1.在类A中我们重载了“=”运算符,由此函数内部我们可以看到返回的是一个临时匿名对象,而且是非引用方式,所以不会改变对象a本身的值,很容易在输出结果中得出答案。
  2.而( a = 20 )这整个表达式所返回是一个在重载了“=”运算符函数中的临时匿名对象,按照C++规定,临时匿名对象的生存期被定在一句语句的结束,但是我们看到,当程序离开重载“=”运算符函数的时候,临时匿名对象并没有被析构,那是什么原因呢,那我们来看看程序分析一下:
Constructor is Called...    ,addr = 0027FC84
这个是进入到重载“=”运算符函数时候,因为创建了一个临时匿名对象所引发的构造函数调用,这个临时匿名对象的地址就是0027FC84,然后再看输出结果,我们发现对象b的地址也是0027FC84,难道b就是临时匿名对象?其实是编译器为了效率就直接把匿名对象变为b对象,这样就省了对b对象进行重新构造。

0 0