先来看一段代码
#include <iostream>
using namespace std;
class A
{
public:
A(){
cout << "A() ...." << endl;
}
~A()
{
cout << "~A()...." << endl;
}
void func()
{
cout << "a --> func()...." << endl;
}
};
class MyAutoPtr //定义一个指向A类的智能指针
{
public:
MyAutoPtr(void* ptr) //ptr = new A;
{
this->m_p = ptr;
}
~MyAutoPtr()
{
if (this->m_p != NULL) {
cout << "delete m_p" << endl;//打印信息,表示已运行MyAutoPtr类的析构函数
delete m_p;
}
}
private:
void* m_p;//指向A对象的地址。
};
void test()
{
MyAutoPtr auto_p(new A); //创建一个对象,并在test函数结束时销毁
}
int main(void)
{
test();
return 0;
}
输出结果如下
A() ....
delete m_p
这段代码中MyAutoPtr类中有一个void类指针m_p指向类A,最后在对象auto_p销毁时调用MyAutoPtr类中析构函数释放掉m_p指向的内存即类A,按理来说是会调用类A的析构函数进行进一步的释放,但是输出结果表示系统只运行到了MyAutoPtr类中的析构函数,并未调用类A的析构函数,这就造成了类A的内存并未被释放。
若将MyAutoPtr类中的指针m_p改为A类型,再次运行就显示正确的调用了类A的析构函数。
由此可知,若一个void类型指针指向了一个类,那么系统在释放这个指针时并不会调用该类中的析构函数去释放内存,会造成内存泄漏。这也是为什么C++中模板类大多需要调用者在调用时显式标注数据类型的原因。
————————————————
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
2019-01-16 流媒体压力测试rtmp&hls(含推流和拉流)
2019-01-16 RTMP与HLS压力测试工具安装与配置
2019-01-16 HTTP/HLS/RTMP超级负载测试工具
2019-01-16 windows迁移linux问题集锦
2017-01-16 hisi出的H264码流结构
2014-01-16 windows消息处理(强烈推荐,收藏)
2013-01-16 Button按钮响应鼠标按下与弹起消息