首先,在父类的构造函数中无法实现多态。
即在子类对象构造时,调用父类的构造函数时,执行的print()函数,仍然是父类中定义的虚函数print(),而不是子类中的虚函数print()。
原因:这是因为在创建子类对象,调用父类的构造函数时,VPTR指针会从指向子类的虚函数表转而指向父类的虚函数表有关。
- 当类A中含有虚函数时,在创建类A的对象时,编译器会为A创建一个VPTR指针,并创建一个虚函数表,存放各个虚函数的入口地址。在子类B的对象创建时,也是如此。此外,子类会继承父类的虚函数表,对于同名的(虚)函数进行重定义。当使用子类对象调用父类中的虚函数时,要加父类名作为域作用符。即 B b; b.A::print();进行父类中的虚函数同名虚函数调用。以原来的代码中,父类中的两参数虚函数virtual void fun(int i,int j)使用子类对象child调用为例。