派生类的构造函数和析构函数的调用顺序
通常情况下:
当创建派生类对象时:
基类的构造函数——>派生类的构造函数;
当撤消派生类对象时:
派生类的析构函数——>基类的析构函数。
1.派生类的构造函数和析构函数的调用顺序
(1)
输出的是:基类的构造函数
基类的构造函数
派生类的构造函数
输出的是: 派生类的析构函数
基类的析构函数
基类的析构函数
(2)
若同一层次中同时包含虚基类和非虚基类,应先调用虚基类的构造函数,再调用非虚基类的构造函数,最后调用派生类构造函数;
D(int sa,int sb,int sc,int sd):B(sa),B1(sa,sb),B2(sa,sc)
构造函数执行顺序:B()-> B1()->B2()-> D()
析构函数相反
(3)当父类的指针new一个子类的对象时,
父类析构不是虚析构,则delete的时候不调用子类的,只是调用父类的析构函数,如果是virtual的析构函数,则先子类之后父类
具体看例题:
解释:
A *a = new C();是调用父类的指针new一个子类的对象
即:A B C deA
若A中的析构函数是virtual,则A B C deC deB deA
当子类的指针new一个子类的对象时,构造析构都会调用父类
C *c = new C();
子类的指针new一个子类的对象,先构造(父->子)后析构(子->父)
结果A B C deC deB deA
Base * pb = new Child(1), 首先创建子类对象,初始化为1;
func1()不是虚函数,所以pb->func1()执行的是基类的func1函数,i= 10,然后调用func2()函数;
这里的func2是虚函数,要往下派生类寻找,找到后执行派生类中的func2(),此时,i = 12;
最后执行pb->getValue(),结果为12
故选C