析构函数
要:当派⽣类对象中有内存需要回收时,如果析构函数不是虚函数,不会触发动态绑定,只会调⽤基类析构函数,导致派⽣类资源⽆法释放,造成内存泄漏。
构造函数
可以设,但没意义:C++的机制使得基类的构造函数在被调用时是按照静态类型进行调用的,而不是按照动态类型进行调用的。无论基类的构造函数是否是虚函数,都会调用基类的实际构造函数。
那么,为什么C++要设定这样的机制呢?
1.构造需要顺序,构造一个对象的时候,必须知道对象的实际类型,而虚函数行为是在运行期间确定实际类型的。而在构造一个对象时,由于对象还未构造成功。编译器无法知道对象的实际类型,是该类本身,还是该类的一个派生类,或是更深层次的派生类。
换个说法,基类部分的初始化是必须先完成的。如果构造父类对象部分的时候调用子类的虚函数实现(动态类型),可能会导致基类部分没有被完全初始化,从而导致程序崩溃。
2.虚函数的执行依赖于虚函数表。而虚函数表在构造函数中进行初始化工作,即初始化vptr,让他指向正确的虚函数表。而在构造对象期间,虚函数表还没有被初 始化,将无法进行。
补充说明
静态类型,动态类型<