多重继承、虚基类继承时,没有显式调用基类构造函数,对象是如何初始化的问题...

//多重继承、虚基类继承时,没有显式调用基类构造函数,对象是如何初始化的问题
#include <iostream>
using std::cout;
using std::endl;

class Base
{
    public:
        Base(){cout << "hahahha"
                    << endl;n = 78;}
        Base(int n0){cout << "Base\t" 
                         << n0
                         << endl;n = n0;}
        int n;
};

class C_A0: virtual public Base
{
    public:
        C_A0(){}
        C_A0(int n0,int n1):Base(n0){cout << "C_A0\t"
                                          << n1
                                          << endl;}
};

class C_A1: virtual public Base
{
    public:
        C_A1(){}
        C_A1(int n0,int n1):Base(n0){cout << "C_A1\t"
                                          << n1
                                          << endl;}
};

class C_B0: public C_A0,public C_A1 
{
    public:
        C_B0(){};
        C_B0(int n,int n0,int n1,int n2):C_A0(n0,n0),C_A1(n1,n1)//没有显式地调用基类构造函数
        //在基类是虚拟的时,禁止信息通过中间类自动传递给基类,因此,C_A0(n0,n0),C_A1(n1,n1)中的第二个参数将传递给对应的类,
        //而第一个参数不会传递给子对象Base,子对象调用的是默认构造函数。如果没有默认构造函数,将报错:,error: no matching
        //function for call to 'Base::Base()'
        {
          cout << "C_B0\t" << n2 << endl;
        }
};

int main()
{  
    C_B0 a(1,2,3,4);  //没有显式地调用Base(int n0)构造函数,因此调用默认构造函数,输出"hahahha"
    cout << &(a.C_A1::n) << '\t' << (a.C_A1::n) << endl;  //
    cout << &(a.C_A0::n) << '\t' << (a.C_A0::n) << endl; //由运行结果可知,派生类对象a从Base类中继承了两个n成员数据,这两个n成员数据是相同的
    return 0;
}

运行结果

image

转载于:https://my.oschina.net/libowen/blog/95574

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值