虚基类和多重继承总结

1,虚基类,其构造函数总是在最后一个层次最先并且真正被执行。
实例代码:

#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");
}


输出:
[quote]B from G
C from G
A from E
E from G
D from F
F from G
G from main[/quote]

总结:虚基类构造函数最先被执行,然后按照从左到右,从上到下的顺序依次执行每一个构造函数。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值