废话不多说,先上代码:
#include <iostream>
using namespace std;
class Other {
public:
Other() { cout << "Other构造。\n"; }
~Other() { cout << "Other析构。\n"; }
};
class Animal {
public:
Animal() { cout << "父类构造函数。\n"; }
~Animal() { cout << "父类析构函数。\n"; }
};
class Dog :public Animal {
public:
Dog() { cout << "子类构造函数。\n"; }
Other o;
~Dog() { cout << "子类析构函数。\n"; }
};
int main() {
Dog bob;
return 0;
}
其中Animal为父类,Dog为子类,Other为其他类,最终在子类中实现为成员类。
运行结果为:
结论:
构造函数执行顺序:基类构造函数→类成员对象的构造函数→子类构造函数。
析构函数执行顺序:子类析构函数→类成员对象析构函数→父类析构函数。
面对更加复杂的情况:
如果有多个基类,构造函数的顺序是某类在某子类表中出现的顺序。
如果有多个类成员对象,构造函数的顺序是对象在类中被声明的顺序。
析构函数中顺序则相反。