构造函数和析构函数中的虚函数
在执行基类构造函数时,对象的派生类部分是未初始化的。实际上,此时对象还不是一个派生类对象。
为 了适应这种不完整,编译器将对象的类型视为在构造或析构期间发生了变化。在基类构造函数或析构函数中,将派生类对象当作基类类型对象对待。
如果在构造函数或析构函数中调用虚函数,则运行的是为构造函数或析构函数自身类型定义的版本。
class Base { public: Base() { Fuction(); } virtual void Fuction() { cout << "Base::Fuction" << endl; } }; class A : public Base { public: A() { Fuction(); } virtual void Fuction() { cout << "A::Fuction" << endl; } }; // 这样定义一个A的对象,会输出什么? A a;
Base::Fuction
A::Fuction
先调用父类的构造函数,调用父类的Function,因为此时虚函数表还未构造完成,然后调用子类构造函数,子类构造函数直接调用子类的Function。
符合 运行的是为构造函数或析构函数自身类型定义的版本 这一原则