对象在创建的时,由编译器对vpt指针进行初始化,只有当对象的构造完全结束后vpt的指向才最终确定,父类对象的vpt指向父类虚函数表,子类对象的vpt指向子类虚函数表。
如下面的例子:
#include <iostream>
using namespace std;
class Animal
{
public:
Animal(string _name) :name(_name)
{
test(); //执行哪个函数?
}
virtual void test()
{
cout << "父类test函数调用" << endl;
}
virtual ~Animal() { cout << "~Animal" << endl; }
protected:
string name;
};
class Mouse : public Animal
{
public:
Mouse(string _name, bool _sex) : Animal(_name), sex(_sex) {}
virtual void test()
{
cout << "子类test函数调用" << endl;
}
virtual ~Mouse() { cout << "~Mouse" << endl; }
protected:
bool sex;
};
void Pause()
{
Mouse m("Aem", 2);
}
int main()
{
Pause();
return 0;
}
初始化对象m的vptr指针是分步进行的,当执行父类的构造函数时,m.vptr指向父类的虚函数表,因此在父类的构造函数中执行父类的test()函数,当父类的构造函数执行完毕后,会把m.vptr指向子类的虚函数表。