构造函数中显式地调用虚函数:
#include <iostream>
using namespace std;class Base{
public :
Base(){
cout << "Base constructor" << endl;
Init();
}
virtual void Init(){
cout << "Base::Init " << endl;
}
};
class Derived :public Base{
public :
Derived():Base(){
cout << "Derived constructor" << endl;
}
virtual void Init(){
cout << "Derived::Init " << endl;
}
};
int main(){
Derived d;
return 0;
}
Result:
Base constructor
Base::Init
Derived constructor
构造函数:在派生类被正确构造出来之前,调用派生类的虚成员函数是没有意义的,在基类构造器运行的时候派生类的数据成员还没有被初始化。派生类的正确构造必须以基类的正确构造为前提。由于此时派生类对象的数据成员尚未被初始化,不应允许多态行为的发生,只能退而求其次,调用基类的虚函数 Init 了。
================================================
析构函数:在对象析构期间,存在与上面类似的逻辑:执行哪个虚函数取决于它被绑定到了哪里。析构顺序遵从的是从继承类到基类,一旦派生类数据析构,在基类析构函数中调用虚函数就没了“多态的能力”,C++仅仅会将其作为一个基类对象来进行处理。
================================================
如果为纯虚函数,调用成功的机会都没有。