构造函数和变量初始化顺序
来源:互联网 发布:淘宝可以办假的毕业证 编辑:程序博客网 时间:2024/06/15 03:52
class A
{
public:
A(){ cout<<"A()"<<endl;}
~A(){ cout<<"~A()"<<endl;}
};
class B
{
public:
B(){ cout<<"B()"<<endl; }
~B(){ cout<<"~B()"<<endl; }
private:
A a;
};
class C :public B
{
public:
C(){ cout<<"C()"<<endl;}
~C(){cout<<"~C()"<<endl;}
private:
B b;
A a;
};
int _tmain(int argc, _TCHAR* argv[])
{
C* p = new C;
delete p;
return 0;
}
输出:
A() //这一行和下一行是为了构造C类对象的基类B,而在构造基类B的时候需要先初始化B的成员变量a,因而调用了A的构造函数
B()
A() //这一行和下一行是C类对象在初始化成员变量b时,需要构造B,因此需要先初始化B的成员变量a,因而再次调用了A的构造函数
B()
A() //这一行是C类对象初始化成员变量a是,需要构造A
C() //构造完毕C类对象的基类B和自身成员变量a,b之后,调用自己的构造函数
~C() //析构次序和构造次序相反
~A()
~B()
~A()
~B()
~A()
大家可以验证做一些测试,比如把B改为
class B
{
public:
B(){ cout<<"B()"<<endl; }
~B(){ cout<<"~B()"<<endl; }
};
这样输出结果:
B()
B()
A()
C()
~C()
~A()
~B()
~B()
看到了吧,这样C在构造基类对象B和初始化成员变量b的时候就不用再构造A,因此就去掉了A()。
总结:初始化一个类对象的时候,首先构造这个类的基类,接着初始化这个类的成员变量,最后调用构造函数。自然,析构的顺序和构造次序相反。
- 构造函数和变量初始化顺序
- static 变量和static 构造函数 以及对象初始化顺序
- Java 代码块、成员变量初始化、构造函数初始化顺序
- java变量,初始化快,构造函数的执行顺序
- java变量,初始化快,构造函数的执行顺序
- java变量,初始化快,构造函数的执行顺序 .
- 构造函数及其成员变量初始化顺序详解
- java变量,初始化快,构造函数的执行顺序
- java变量,初始化快,构造函数的执行顺序
- java变量,初始化快,构造函数的执行顺序
- C++成员变量、构造函数的初始化顺序
- 构造函数中成员变量初始化顺序问题
- c++构造函数以及类中变量初始化顺序
- java变量,初始化快,构造函数的执行顺序
- java变量,初始化快,构造函数的执行顺序
- java变量,初始化快,构造函数的执行顺序
- C++成员变量、构造函数的初始化顺序
- java变量,初始化快,构造函数的执行顺序
- Spring配置文件中配置数据源(dataSource)
- windows内核情景分析学习笔记4
- 多行文本框如何限制输入字数方法
- Android 中的长度单位详解 dp、sp、px、in、pt、mm
- 新的Symbian OS 9 可执行文件格式(E32Image)
- 构造函数和变量初始化顺序
- 团购网站 购物js
- PKU 3537
- Running an Active Object in OpenC
- Windows CE S3C2440A显示驱动编码分析
- 积分啊
- linux spi驱动分析
- c++ 动态数组的实现
- Taobao分布式文件系统TFS简析