多继承时的构造函数调用的顺序
2014-01-17 00:03
190 查看
调用顺序是:虚基类——直接基类——子对象——派生类
我们假设一个非常复杂的情况:
class A;
class B: virtual public A;
class C: virtual public A;
class E;
class D:public B, public C
其中E是D的子对象
首先说明,构造函数的调用顺序,跟D中的构造函数调用个类的成员函数的顺序无关
因为B和C都是虚继承自A,所以首先调用都在A的构造函数,然后根据类D继承B,C的顺序调用B,C的构造函数;
然后调用子对象构造函数,因为构造子对象E是构造D的任务的一部分
下面是完整代码:
输出结果:
我们假设一个非常复杂的情况:
class A;
class B: virtual public A;
class C: virtual public A;
class E;
class D:public B, public C
其中E是D的子对象
首先说明,构造函数的调用顺序,跟D中的构造函数调用个类的成员函数的顺序无关
因为B和C都是虚继承自A,所以首先调用都在A的构造函数,然后根据类D继承B,C的顺序调用B,C的构造函数;
然后调用子对象构造函数,因为构造子对象E是构造D的任务的一部分
下面是完整代码:
#include<iostream> using namespace std; class A { public: A(char a1) { cout<<"constructor A called"<<endl; } }; class B:virtual public A { public: B(char a1,char b1):A(a1) { cout<<"constructor B called"<<endl; } }; class C:virtual public A { public: C(char a1,char c1):A(a1) { cout<<"constructor C called"<<endl; } }; class E { public: E(char e1) { cout<<"constructor E called"<<endl; } }; class D:public B,public C //继承的顺序决定了构造的先后 { char d; E e; public: //派生类成员初始化列表可以随意,所以我故意打乱了顺序 D(char a1,char b1,char c1,char d1,char e1):C(a1,c1),B(a1,b1),e(e1),d(d1),A(a1) { cout<<"constructor D called"<<endl; } }; int main() { D d('1','2','3','4','5'); }
输出结果:
相关文章推荐
- c++学习笔记5,多重继承中派生类的构造函数与析构函数的调用顺序(二)
- C++多重继承中构造函数和析构函数调用顺序举例
- 继承中构造函数和析构函数地调用顺序
- 多继承且有内嵌对象时构造函数的调用顺序
- 多继承时的构造函数调用的顺序
- C++虚继承(七) --- 虚继承对基类构造函数调用顺序的影响
- 继承中的构造函数调用顺序
- 继承中构造函数和析构函数的调用顺序
- C++类的继承中构造函数和析构函数调用顺序例子
- C++类的继承中构造函数和析构函数调用顺序例子
- C++ 虚继承对基类构造函数调用顺序的影响
- C++ 多继承构造函数初始化列表调用顺序
- java继承的对象中构造函数的调用顺序
- C++继承中构造函数、析构函数调用顺序及虚析构函数
- C++继承中构造函数、析构函数调用顺序及虚析构函数
- C++虚继承(九) --- 构造函数调用顺序的实用之处
- 继承关系中基类和子类构造函数的调用顺序
- C++继承中构造函数、析构函数调用顺序及虚析构函数
- C++继承中构造函数、析构函数调用顺序及虚函数的动态绑定
- C++多继承构造函数调用顺序