前面介绍了单继承以及正常多继承的内存分布情况,最后介绍一种虚继承的情况。同时虚继承也是解决多继承二义性的一种手段。
首先将代码改动如下,
Base1跟Base11是完全一样的代码,除了继承的时候Base1是虚继承,我们先看下单继承的时候,虚继承的内存分布跟非虚继承有什么区别。
可以看到虚继承的内存分布要复杂的多。有两个vftable以及一个vbtable。第一个表是Base1本身的,第二个虚表是父类Base的。而vbtable叫虚基类表,它记录了类继承的所有的虚基类子对象在本类定义的对象内的偏移位置。
接下来,我们看更复杂的情况。
SubBase继承了俩个类,且这两个类都采用了虚继承的方式继承了一个共同的Base。
内存分布可以看到,首先是直接基类Base1, Base2的vftable,接着是他们各自的vbtable,而对于共同基类Base的vftable则放在了最后,这也保证了不管有多少个基类,都可以很容易的找到他们共同的基类。