多重继承和虚基类

//派生类成员函数对基类成员函数的覆盖

#include "stdafx.h"

#include<iostream>

class A

{

public:

     void Show()

     {

         std::cout<<"A::Show/n";

     }

};

 

class B:public A

{

public:

     void Show()

     {

         std::cout<<"B::Show/n";

     }

     void Display()

     {

         Show();//调用派生类B的成员函数,覆盖掉继承自基类的Show()成员方法

         A::Show();//调用基类A的成员函数

     }

};

int _tmain(int argc, _TCHAR* argv[])

{

     A a;

     B b;

     a.Show();

     b.Show();

     b.Display();

     std::cin.get();

     return 0;

}

程序运行的结果:

A::Show

B::Show

B::Show

A::Show

一个派生类对象含有基类的数据成员的一个副本,在C++类的多重继承结构中,由于多层次的交叉派生关系,一个派生类中可能保留某个基类的多个实例。例如,在下图中,B:A,C:A,D:B,D:C,这是在派生类D的对象中存在间接基类A的两份副本。当试图通过派生类对象直接访问基类A中的成员是,将会导致编译二义性错误。

//多重继承的副本二义性

class A

{

public:

     int a;//a

};

 

class B:public A

{

public:

     int b;//a,b

};

class C:public A

{

public:

     int c;//a,c

};

class D:public B,public C

{

public:

     int d;//(a,b),(a,c),d

};

 

int _tmain(int argc, _TCHAR* argv[])

{

     D d1;

     d1.a=100;//此处a具有二义性,编译器无法确定a是那个副本

     d1.B::a=100;//指明访问的是通过B类间接派生的

     d1.C::a=100;//指明访问的是通过C类间接派生的

return 0;

}

编译结果:error C2385: ambiguous access of 'a'

若注释掉d1.a=100;则编译通过。

在多重继承中,C++提供了虚基类(virtual base class)来解决二义性的问题。虚基类只是一种派生的方式,类层次结构中某个虚基类成员只出现一次,即基类的一个副本被所有派生类对象共享。修改上例代码中BC的派生方式则d1.a=100;是合法的。

class B:public virtual A

{

public:

     int b;//a,b

};

class C:public virtual A

{

public:

     int c;//a,c

};

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值