2011年03月25日

来源:互联网 发布:广告公司软件免费版 编辑:程序博客网 时间:2024/06/18 05:45

#include<iostream>
using namespace std;

class A...{
    public:
        int a;
    public:
    A(int _a)
    ...{
        a = _a;
    }
    A()
    ...{
        A(11);
    }
};
int main(int argc,char* argv[])
...{
    A aa;
    cout<<aa.a<<endl;
    return 0;
}该程序的运行结果让我傻眼了,结果输出a的值不确定。为什么在默认构造函数中调用另一个构造函数确没有改变a的值呢???后来才明白,其实A(11)是调用另一构造函数并产生一临时变量,而不是去用另一构造函数去构造默认构造函数。

1)在c++里,由于构造函数允许有默认参数,使得这种构造函数调用构造函数来重用代码的需求大为减少。

2)如果仅仅为了一个构造函数重用另一个构造函数的代码,那么完全可以把构造函数中的公共部分抽取出来定义一个成员函数(推荐为private),然后在每个需要这个代码的构造函数中调用该函数即可。

3)偶尔我们还是希望在类的构造函数里调用另一个构造函数,可以按下面方式做:

在构造函数里调用另一个构造函数的关键是让第二个构造函数在第一次分配好的内存上执行,而不是分配新的内存,这个可以用标准库的placement new做到。

  先看看标准库中placement new的定义

inline void *__cdecl operator new(size_t, void *_P)

{

    return (_P);

}

 调用上述的函数没有分配新的内存,这正是我们想要的。因此我们可以这样在一个构造函数里调用另一个构造函数:


A()
...{
    new(this)A(11);
}注: 若构造函数调用自身,则会出现无限递归调用,是不允许的。一般按上文中第二点编写代码。

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/leatinfy/archive/2008/03/17/2192409.aspx

原创粉丝点击