1.当基类的析构函数为虚函数时,那么派生类的析构函数自动为虚函数
2.当基类的指针指向派生类的对象时,如果析构函数不是虚函数,就不会发生动态多态,导致只会调用基类的析构函数,造成内存泄漏
3.虚函数原理及虚函数表:
一旦类中引入了虚函数,在编译期间就会创建虚函数表,表中每一项数据都是虚函数的入口地址。为了将对象与虚函数表关联起来,编译器会在对象中会增加一个指针成员用于存储虚函数表的位置
基类的指针指向派生类对象时就是通过虚函数表的指针来找到实际应该调用的函数
虚函数表原理:
基类与派生类都维护自己的虚函数表,如果派生类重写基类的虚函数,则虚函数表存储的是派生类的函数的地址没有重写的虚函数教则保存的是基类的虚函数表
当要获取虚函数表的地址以及虚函数表的内容(虚函数的地址),可以使用以下代码进行验证