这似乎很明显。
如果base class的destructor不是virtual,当其derived class作为基类使用,析构的时候derived class的数据成员将不会被销毁。
举个例子 我们有个交通工具的类作为基类, 它的析构函数不是virtual
class transportTool
{
public:
~transportTool();
}
然后有一个汽车类继承它
class auto: public transportTool
{
public:
int numWheels;
~auto();
}
我们在程序中使用工厂方法产生这个作为交通工具的汽车类
{
transportTool *tool;
tool = new auto();
delete tool;//here delete transportTool but the destructor of auto not called so numWeels data member not destroyed
}
解决方法就是把析构函数声明称virtual
原则就是如果类中有被其他类继承的可能性(尤其类中有其他virtual函数)就把析构函数声明称virtual。单也不是所有时候都需要virtual 析构函数。
一个小窍门, 当需要一个abstract class 但是没有纯虚函数时,可以把析构函数声明成纯虚,但这时必须为这个析构函数提供一个定义,否则它被其他类继承时,继承类的析构函数会调用基类的析构函数,如果没有定义,会出错。
class abstractBaseClass
{
public :
virtual ~abstractBaseClass()=0;
}
//abstractBaseClass.cpp
abstractBaseClass::~abstractBaseClass(){}
原文链接: https://www.cnblogs.com/williamwood/p/3817571.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/136238
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!