1、如果父类的析构函数不是虚函数,则不会触发动态绑定(多态),结果就是只会调用父类的析构函数,而不会调用子类的析构函数,从而可能导致子类的内存泄漏(如果子类析构函数中存在free delete 等释放内存操作时);
2、如果父类的析构函数是虚函数,则子类的析构函数一定是虚函数(即使是子类的析构函数不加virtual,这是C++的语法规则),则会在父类指针或引用指向一个子类时,触发动态绑定(多态),析构实例化对象时,若是子类则会执行子类的析构函数,同时,编译器会在子类的析构函数中插入父类的析构函数,最终实现了先调用子类析构函数再调用父类析构函数。
为什么父类的析构函数必须是虚函数,而C++默认的析构函数不是虚函数?
因为当我们用基类指针指向new出来的子类时,根据 动态绑定可以确保子类新添加的部分也可以被顺利释放掉,以防出现内存泄漏。
而默认的析构函数不是虚函数的原因是因为:虚函数需要额外的 虚函数表和 虚表指针,会占用格外内存,对于不会有子类的类来说,这个是没有必要的。
原文链接: https://www.cnblogs.com/7star/p/17086427.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/315603
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!