假设有这样的关系
class A;
class B:public class A;
定义:A* pA = new B;
当执行这句的时候,首先调用A的构造函数,此时this指向的的vptr的内容是A中所有的虚函数地址。A构造完后,执行B的构造函数,如果B中改写了A的虚函数,则B中改写的虚函数的地址将替代this指向的vptr中相应虚函数的地址。
按照上面的分析,可以得出以下结论:
- pB指向的vptr是运行时赋值,因此达到了运行时绑定的效果。
- 在A的构造函数中调用虚函数,即使B中改写了该虚函数,也无法调用到B的虚函数。因为此时B的构造函数还没执行,vptr还未被改写。