为何需要虚析构函数

派生类对象传递给基类参数时,并通过该参数调用函数时,将执行基类的函数。然而,还存在一个问题:如果基类指针指向的是派生类对象,通过该指针调用运算符delete时,结果将会如何呢?

为何需要虚析构函数_第1张图片
运行结果:
为何需要虚析构函数_第2张图片
注意⚠️:
由于使用了关键字new,在自由存储区中构造函了Tuna和Fish,但delete没有调用Tuna的析构函数,而只调用了Fish的析构函数;而构造和析构的局部变量tuna时,调用了基类的和派生类的构造函数和析构函数。派生类对象的构造和析构过程;它表明在析构过程中,需要调用相关的析构函数,包括~Tuna();显然是什么地方出问题了。
对于使用new在自由存储区的实例化的派生类对象,如果将其赋给基类指针,并通过该指针调用delet,将不会调用派生类的析构函数。这可能导致资源未释放,内存泄漏等问题。
要避免这种问题,可将析构函数声明为虚函数。确保基类指针调用delete时,将调用派生类的析构函数。

你可能感兴趣的:(c+注意)