在虚基类的构造函数中,调用虚函数和纯虚函数存在不同,如下代码:
#include <iostream>
class TestParent
{
public:
TestParent()
{
say();
//compile error
//work();
}
virtual ~TestParent(){}
virtual void say(){printf("this is parent!\n");}
virtual void work() = 0;
};
class TestSon : public TestParent
{
public:
TestSon()
{
}
virtual ~TestSon(){}
virtual void say(){printf("this is son!\n");}
virtual void work(){printf("the son is working...\n");}
};
int main(int argc, char *argv[])
{
TestParent *testObj = new TestSon();
delete testObj;
return 0;
}
上面的例子将会输出:
this is parent!
是不是有点不可思议.
在创建testObj对象时,实际执行过程是:
1)new TestSon() 时,首先调用基类的构造函数TestParent::TestParent()
2)当执行TestParent::TestParent()时,当前实例化的指针的类型还不是TestSon,它的类型是TestParent。因此这时调用了TestParent::say()。
C++箴言:
·在构造和析构期间不要调用虚函数,因为这样的调用不会匹配到当前执行的构造函数或析构函数所属的类的更深的派生层次。