DoubleLi

qq: 517712484 wx: ldbgliet

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  4737 随笔 :: 2 文章 :: 542 评论 :: 1615万 阅读
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

先来看一段代码

#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++中模板类大多需要调用者在调用时显式标注数据类型的原因。
————————————————

posted on   DoubleLi  阅读(1022)  评论(0编辑  收藏  举报
编辑推荐:
· 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按钮响应鼠标按下与弹起消息
点击右上角即可分享
微信分享提示