您的位置:首页 > 其它

构造、析构函数的调用顺序及VC6.0和VC2010中实现的差别

2013-05-24 11:31 375 查看
构造、析构函数的调用顺序及VC6.0和VC2010中实现的差别

VC6.0和VC2010在初始化数组的时候存在差别:对于
vector<Item_base> ibvec( 3 );


在6.0中这条语句是先利用默认构造函数创建一个临时对象,然后三次调用复制构造函数,将此临时对象赋给数组中的值,再调用析构函数撤销临时对象;
在2010中,这条句是先利用默认构造函数创建一个临时对象,然后调用复制构造函数将此临时对象赋给数组中的一个值, 再调用析构函数撤销临时对象;再反复这个过程初始化数组的另外两个值。
详细代码如下:
#include <iostream>
#include <vector>
using namespace std;

class Item_base
{
public:
Item_base()
{
cout << "Item_base()" << endl;
}
Item_base( const Item_base& )
{
cout << "Item_base( const Item_base& )" << endl;
}
Item_base& operator = ( const Item_base &rhe )
{
cout << "operator = ( const Item_base& )" << endl;
return *this;
}
~Item_base()
{
cout << "~Item_base()" << endl;
}
};

void func1( Item_base obj )
{
}

void func2( Item_base &obj )
{
}

Item_base func3()
{
Item_base obj;
return obj;
}

int main()
{
Item_base ib;
func1( ib );
func2( ib );
ib = func3();
Item_base *p = new Item_base;
vector<Item_base> ibvec( 3 );
delete p;

return 0;
}


VC6.0中的运行结果:

Item_base()
Item_base( const Item_base& )
~Item_base()
Item_base()
Item_base( const Item_base& )
~Item_base()
operator = ( const Item_base& )
~Item_base()
Item_base()
Item_base()
Item_base( const Item_base& )
Item_base( const Item_base& )
Item_base( const Item_base& )
~Item_base()
~Item_base()
~Item_base()
~Item_base()
~Item_base()
~Item_base()


VC2010中的运行结果:
Item_base()
Item_base( const Item_base& )
~Item_base()
Item_base()
Item_base( const Item_base& )
~Item_base()
operator = ( const Item_base& )
~Item_base()
Item_base()
Item_base()
Item_base( const Item_base& )
~Item_base()
Item_base()
Item_base( const Item_base& )
~Item_base()
Item_base()
Item_base( const Item_base& )
~Item_base()
~Item_base()
~Item_base()
~Item_base()
~Item_base()
~Item_base()
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐