欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 新车 > C++中析构函数不设为virtual导致内存泄漏示例

C++中析构函数不设为virtual导致内存泄漏示例

2025/7/5 3:24:43 来源:https://blog.csdn.net/qq_64875189/article/details/148031724  浏览:    关键词:C++中析构函数不设为virtual导致内存泄漏示例

一、问题示例

#include <iostream>
using namespace std;class Base {
public:Base() { cout << "Base constructor\n"; }~Base() { cout << "Base destructor\n"; } // 不是 virtual
};class Derived : public Base {
public:Derived() { cout << "Derived constructor\n"; }~Derived() { cout << "Derived destructor\n"; }
};int main() {Base* ptr = new Derived();  // 用 Base 指针指向 Derived 对象delete ptr;                 // 只调用 Base 的析构函数return 0;
}

二、输出结果

在这里插入图片描述
注意:没有调用 Derived 的析构函数

三、问题解释

为什么会这样?

  • Base 的析构函数不是 virtual

  • 当你执行 delete ptr,编译器只看 ptr 的静态类型(即 Base*),它就只调用 ~Base()

  • 因此,不会调用 Derived 的析构函数,可能会导致:

    • Derived 析构中释放的资源没有释放(内存泄漏);
    • 或者 Derived 析构中有清理逻辑没执行(行为错误);

四、修复方法

Base 的析构函数设为 virtual

class Base {
public:virtual ~Base() { cout << "Base destructor\n"; }  // virtual 析构
};

正确输出:

在这里插入图片描述


五、图示原理(简化)

如果你用 virtual

Base vtable:
+----------------+
|  &Base::~Base  |  ← 原始虚函数地址
+----------------+Derived vtable:
+--------------------+
| &Derived::~Derived | ← 覆盖虚析构函数
+--------------------+delete ptr 会通过 vtable 跳转到 Derived::~Derived → 再调用 Base::~Base

六、总结

是否 virtualdelete 派生类指针时行为是否内存泄漏
只调用基类析构函数有可能
调用派生 → 再基类析构安全

七、经验建议

只要类中有虚函数(即打算支持多态)或你“可能”通过基类指针删除派生类对象,就应该将析构函数声明为 virtual

最好这样写:

class Base {
public:virtual ~Base() = default;
};

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词