首先看一段代码:
class B { public : int b; }; class D: virtual public B { public : int d; }; int _tmain(int argc, _TCHAR* argv[]) { cout<<sizeof(D)<<endl; };
在vs输出12,当将virtual关键字去掉之后,输出8;可见虚拟继承需要额外的空间开销。在vs中,引入了所谓的“虚基类表”(类似虚函数表),同时每个Class Object中有一个指向虚基类表的指针,虚基类表中存放着对应虚基类对象的指针(地址)。
那么两个虚基类的情况如何呢?我们修改代码如下:
class B { public : int b; }; class B1 { public : int b1; }; class D: virtual public B,virtual public B1 { public : int d; };
结果输出为16,只是增加了新的基类的数据成员(int),并没有增加更多的额外空间,所以进一步说明“虚基类表”的存在,因为所有的虚基类指针都在虚基类表中。