1 C++类的对象构造的时候,首先申请一片内存,然后调用构造函数进行初始化;
我们知道,存在虚函数的话,也会存在一个虚函数表vtable,而虚函数表示在什么时候产生的呢,当然是在调用构造函数之后产生的;
那么问题来了,如果构造函数为虚函数,此时的内存是一片空白,不存在该虚函数表vtable,那么无法找到该构造函数;
所以说,构造函数不能为虚函数。
2 此外,如果有以下代码:
class A{ A() {}};class B: public A{ B():A() {}};int main(){ B b; B *pb = &b;}
则构造B类的时候,构造函数执行顺序是:
A() B()
根据虚函数的性质,如果A的构造函数为虚函数,且B类也给出了构造函数,则应该只执行B类的构造函数,不再执行A类的构造函数,这样A就无法构造了,产生了矛盾;
因此,构造函数不能为虚函数。
对于析构函数而言,可以为虚函数,因为此时虚函数表早已建立;并且,常常析构函数都是虚函数。原因就是,通过基类指针在销毁对象的时候,可以正确的识别要销毁对象的类型,从而防止析构不完全的出现。