多重继承
c++支持多重继承,但细节可能会出现错综复杂的设计和实现问题
声明符 类名 :访问修饰符 基类,访问修饰符 基类……
//
构造:
派生类可以初始化所有的直接基类,基类构造顺序为自顶向下,而非出现在初始值列表的顺序
同单继承一样,派生类可以从一个或多个基类继承构造函数(using),并且在派生类生成形参列表一致的构造函数,从而在多继承中,不能从多个基类继承相同的构造函数,如果出现上述情况,需要为构造函数定义派生类版本
//
拷贝或赋值或移动:
和单继承一样,只有派生类是默认版本,才会隐式的自动执行(所有)基类对应的成员,拷贝或赋值都会自顶向下执行
//
类型转换
派生类对象可以转换为基类指针或引用,在多继承中,并没有优先级
//
名字查找:同单继承一样,无论是否是虚函数,注意静态类型必须包含函数名字声明
多重继承下,首先从派生类内部查找,之后从所有直接基类中同时进行查找,
从基类分别继承相同名字成员是合法的,但如果存在相同的 函数(同名,形参列表一致),将出现二义性,我们必须明确指出使用的版本
解决方式,为函数定义派生类版本
虚继承
派生类有可能多次继承同一个类,比如d->c,b ; c->a ; b->a这种情况,我们通过虚继承解决这种重复继承的问题
虚继承:某个类做出声明,承诺愿意共享它的基类,被共享的基类称为虚基类,这样在继承体系中,无论虚基类出现了多少次,派生类都只包含唯一一个共享的虚基类对象
//
在继承列表中,在要作为虚基类前(访问说明符前后都可以)添加virtual关键字,一个类可以继承多个虚基类,
虚继承体系通常由一次性设计完成
虚基类成员:虽然虚基类被包含一次(放在重复初始化),但内部成员仍由有可能被bc等定义,从而出现二义性错误,但是如果没有定义,或仅有b或c其中一个定义,不会发生二义性
//
初始化和折构:
因为防止被重复初始化,虚基类是由最低层(叶节点)派生类初始化的, 我们可以手动的去调用基类的构造,如果没有手动调用,基类执行默认构造
不同点在于,虚函数无论在继承体系中什么位置,都是先于非虚类构造的,然后再构造非虚类,
比如一个类继承多个虚基类,和非虚基类,从最左侧开始,并确定其中是否包含虚基类,也就是从内到外,从左到右的顺序
折构函数的顺序总是保持和构造顺序相反