如上代码:
输出结果:
为什么测试的结果为36(32位机)呢,其中需要注意的是hanshvirtual关键词。
一个类中若是有虚函数,(不论是自己的虚函数,还是继承而来的),那么类中就有一个成员变量:虚函数指针,这个指针指向一个虚函数表,虚函数表的第一项是类的typedefinfo信息。之后的项为此类的所有虚函数地址。
假设经过成员对齐后的类的大小为sizeof个字节。那么类的sizeof大小可以这么计算:size + 4 *(虚函数指针的个数n)。
带有虚函数的类的sizeof大小,实际上和虚函数的个数不相关,相关的是虚函数指针。
一个空类的大小为什么是1?
解释:
在深度探索C++对象模型中是这样说的:
那时被编译器插进去的一个char,使得这个class的不同实体(object)在内存中分配独一无二的地址。
也就是说这个char是用来表示类的不同对象的。
PS:C++编译器不允许对象为零的长度。试想一个长度为0的对象在内存中怎么存放?怎么获取它的地址?为了避免这种情况,C++强制给这种类插入一个缺省成员,长度为1.如果有自定义的变量,变量将取代这个缺省成员。
2、C++中的虚函数的作用主要是实现了多态的机制。关于多态,简而言之就是用父类型别的指针指向其子类的实例,然后通过父类的指针调用实际子类的成员函数。
对C++ 了解的人都应该知道虚函数(Virtual Function)是通过一张虚函数表(Virtual Table)来实现的。简称为V-Table。在这个表中,主是要一个类的虚函数的地址表,这张表解决了继承、覆盖的问题,保证其容真实反应实际的函数。这样,在有虚函数的类的实例中这个表被分配在了这个实例的内存中,所以,当我们用父类的指针来操作一个子类的时候,这张虚函数表就显得由为重要了,它就像一个地图一样,指明了实际所应该调用的函数。如图所示:
3、带有虚函数的对象自身确实插入了一些指针信息,而且这个指针信息并不随着虚函数的增加而增大。