多重继承,虚继承

多重继承

c++支持多重继承,但细节可能会出现错综复杂的设计和实现问题

声明符  类名 :访问修饰符 基类,访问修饰符 基类……

//

构造:

派生类可以初始化所有的直接基类,基类构造顺序为自顶向下,而非出现在初始值列表的顺序

同单继承一样,派生类可以从一个或多个基类继承构造函数(using),并且在派生类生成形参列表一致的构造函数,从而在多继承中,不能从多个基类继承相同的构造函数,如果出现上述情况,需要为构造函数定义派生类版本

//

拷贝或赋值或移动:

和单继承一样,只有派生类是默认版本,才会隐式的自动执行(所有)基类对应的成员,拷贝或赋值都会自顶向下执行

//

类型转换

派生类对象可以转换为基类指针或引用,在多继承中,并没有优先级

//

名字查找:同单继承一样,无论是否是虚函数,注意静态类型必须包含函数名字声明

多重继承下,首先从派生类内部查找,之后从所有直接基类中同时进行查找,

从基类分别继承相同名字成员是合法的,但如果存在相同的 函数(同名,形参列表一致),将出现二义性,我们必须明确指出使用的版本

解决方式,为函数定义派生类版本

虚继承

派生类有可能多次继承同一个类,比如d->c,b ;  c->a  ; b->a这种情况,我们通过虚继承解决这种重复继承的问题

虚继承:某个类做出声明,承诺愿意共享它的基类,被共享的基类称为虚基类,这样在继承体系中,无论虚基类出现了多少次,派生类都只包含唯一一个共享的虚基类对象

//

在继承列表中,在要作为虚基类前(访问说明符前后都可以)添加virtual关键字,一个类可以继承多个虚基类,

虚继承体系通常由一次性设计完成

虚基类成员:虽然虚基类被包含一次(放在重复初始化),但内部成员仍由有可能被bc等定义,从而出现二义性错误,但是如果没有定义,或仅有b或c其中一个定义,不会发生二义性

//

初始化和折构:

因为防止被重复初始化,虚基类是由最低层(叶节点)派生类初始化的, 我们可以手动的去调用基类的构造,如果没有手动调用,基类执行默认构造

不同点在于,虚函数无论在继承体系中什么位置,都是先于非虚类构造的,然后再构造非虚类,

比如一个类继承多个虚基类,和非虚基类,从最左侧开始,并确定其中是否包含虚基类,也就是从内到外,从左到右的顺序

折构函数的顺序总是保持和构造顺序相反

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值