派生类的构造函数和析构函数的调用顺序

通常情况下:  

当创建派生类对象时:      
基类的构造函数——>派生类的构造函数;  

 

当撤消派生类对象时:      
派生类的析构函数——>基类的析构函数。

 

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