总结一下虚函数与虚继承中的内存分布细节:
1. 如有虚函数,则内存中加入vptr指针,放在内存中最高位置,其余应继承的成员变量(如char [])按就近原则在内存中从近到远分布;
2. 如有虚继承,则在内存汇总加入vbptr指针,指向虚表,表中是距离基类成员变量的偏移量,指针放在vptr(如有)的下面,如有重复拷贝则只继承一份成员变量;
3. 调用虚函数时,存在就近调用原则,如子类没有,但父类中有对应虚函数,优先调用父类而不调用祖父类,调用父类虚函数时,如用到与同名成员变量,使用的是父类的成员变量。(就近原则,对应原则)
4. 使用父类指针指向子类时,指针实际指向的是内存中父类成员变量地址,如调用父类成员函数(不是虚函数),则调用父类函数;如调用虚函数(子类中复写了该函数),或者与子类指针比较,则实际存在强制类型转换,将指针强制类型转换为子类指针,然后调用了子类虚函数。因为虽然说子类复写了该函数,但在vptr指向表中仍存在父类虚函数(如可以使用b.A::dogetdata(),此处B是继承A的,dogetdata()是虚函数复写),所以此处指针出现了强制类型转换。