虚基类和多重继承下构造函数的顺序

1.没有虚基类:

#include <iostream>
#include <cstdio>
using namespace std;

class A
{
public:
    A()
    {
        cout << "A" << endl;
    };
};

class B : public A
{
public:
    B()
    {
        cout << "B" << endl;
    };
};

class C : public A
{
public:
    C()
    {
        cout << "C" << endl;
    };
};

class D : public B, C
{
public:
    D()
    {
        cout << "D" << endl;
    };
};

int main()
{
    B b; //输出: A B 先构造基类,再构造子类
    D d; //输出: A B A C D
    return 0;
}

2.有虚基类:

#include <iostream>
#include <cstdio>
using namespace std;

class A
{
public:
    A()
    {
        cout << "A" << endl;
    };
};

class VB : virtual public A
{
public:
    VB()
    {
        cout << "VB" << endl;
    };
};

class VC : virtual public A
{
public:
    VC()
    {
        cout << "VC" << endl;
    };
};

class VD : public VB, VC
{
public:
    VD()
    {
        cout << "VD" << endl;
    };
};


int main()
{
    VD vd; //输出: A VB VC VD
    //虚基类的subobject总是在最深的地方最先被构造
    return 0;
}
3.存在虚基类的多继承:

#include <iostream>
using namespace std;

class A
{
public:
    A(const string& s)
    {
        cout << "A " << s << endl;
    }
    virtual ~A() {}
};

class B
{
public:
    B(const string& s)
    {
        cout << "B " << s << endl;
    }
    virtual ~B() {}
};

class C
{
public:
    C(const string& s)
    {
        cout << "C " << s << endl;
    }
    virtual ~C() {}
};

class D
{
public:
    D(const string& s)
    {
        cout << "D " << s << endl;
    }
    virtual ~D() {}
};

class E : public A, virtual public B, virtual public C
{
public:
    E(const string& s) : A("from E"), B("from E"), C("from E")
    {
        cout << "E " << s << endl;
    }
};

class F : virtual public B, virtual public C, public D
{
public:
    F(const string& s) : B("from F"), C("from F"), D("from F")
    {
        cout << "F " << s << endl;
    }
};

class G : public E, public F
{
public:
    G(const string& s) : B("from G"), C("from G"), E("from G"),  F("from G")
    {
        cout << "G " << s << endl;
    }
};

int main()
{
    //虚基类的构造函数最先执行
    G g("from main");
}

输出: 

引用
B from G 
C from G 
A from E 
E from G 
D from F 
F from G 
G from main
总结:虚基类构造函数最先被执行,然后按照从左到右,从上到下的顺序依次执行每一个构造函数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值