虚基类是为了消除歧义和保持基类成员一个拷贝而产生的概念。当在多条继承路径上有一个公共的基类,在这些路径中的某几条汇合处,这个公共的基类就会产生多个实例(或者说是多个副本),如果想要保持这个基类的一个实例,可以将这个公共基类说明为虚基类。
在继承中产生歧义的原因可能是继承类继承了基类多次,从而产生了多个拷贝,即不止一个通过多个路径继承基类,导致在内存中创建了基类成员的多个拷贝。虚基类的基本原则是在内存中只有基类成员的一份拷贝。这样,通过吧基类继承声明为虚拟的,就只能继承基类的一份拷贝,从而消除歧义。使用virtual限定符吧基类继承说明为虚拟的。
虚基类的初始化:
虚基类的初始化与一般继承的初始化在语法上没有任何区别,但是构造函数的调用次序有所不同。派生类构造函数的调用次序必须满足一下三个原则:
[color=red][b](1) 虚基类的构造函数在非虚基类之前被调用;[/b][/color]
[color=blue][b](2) 如果同一层次包含多个虚基类,这些虚基类的构造函数按它们说明次序调用;[/b][/color]
[color=green][b](3) 若虚基类由非虚基类派生而来,则依然优先调用基类构造函数,再调用派生类的构造函数。[/b][/color]
在继承中产生歧义的原因可能是继承类继承了基类多次,从而产生了多个拷贝,即不止一个通过多个路径继承基类,导致在内存中创建了基类成员的多个拷贝。虚基类的基本原则是在内存中只有基类成员的一份拷贝。这样,通过吧基类继承声明为虚拟的,就只能继承基类的一份拷贝,从而消除歧义。使用virtual限定符吧基类继承说明为虚拟的。
虚基类的初始化:
虚基类的初始化与一般继承的初始化在语法上没有任何区别,但是构造函数的调用次序有所不同。派生类构造函数的调用次序必须满足一下三个原则:
[color=red][b](1) 虚基类的构造函数在非虚基类之前被调用;[/b][/color]
[color=blue][b](2) 如果同一层次包含多个虚基类,这些虚基类的构造函数按它们说明次序调用;[/b][/color]
[color=green][b](3) 若虚基类由非虚基类派生而来,则依然优先调用基类构造函数,再调用派生类的构造函数。[/b][/color]