析构函数中delete内存泄露问题求解

gldcpp 2016-09-08 05:28:20
classA:

class ClassA
{
public:
ClassA();
~ClassA();

void destroy();

private:
char* test;

};
ClassA::ClassA()
{
test = new char;
}
ClassA::~ClassA()
{
if (test != NULL)
{
delete test;
}

}


main函数中:
#ifdef _DEBUG //重载new  
#define new new(_NORMAL_BLOCK, __FILE__, __LINE__)
#endif
#include <iostream>
#include <Windows.h>
#include "Base.h"

#include "TestA.h"

using namespace std;

int main()
{

ClassA a;
_CrtDumpMemoryLeaks();
}

退出程序后输出
Detected memory leaks!
Dumping objects ->
{141} normal block at 0x0044B820, 1 bytes long.

求解这里出现问题的原因
...全文
144 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
paschen 版主 2016-09-08
  • 打赏
  • 举报
回复
引用 3 楼 gldcpp的回复:
引用 1 楼 cutmelon 的回复:
_CrtDumpMemoryLeaks();调用的时候还没有执行delete,你的代码其实没有内存泄露的。较真的话,你把 ClassA a;这句用 { } 包起来,保证检测不到了,注意理解 作用域 这个概念
请问 __RTC_CheckEsp 这个的作用是什么,之前我发现这个在函数结束前出现一次同时在线程退出前调用@__security_check_cookie@4后又出现了一次,误以为这个就是_CrtDumpMemoryLeaks的检测
检查esp和esi的是否一致,即检查堆栈在函数后是否平衡
paschen 版主 2016-09-08
  • 打赏
  • 举报
回复
析构函数是在_CrtDumpMemoryLeaks();才被调用
gldcpp 2016-09-08
  • 打赏
  • 举报
回复
引用 1 楼 cutmelon 的回复:
_CrtDumpMemoryLeaks();调用的时候还没有执行delete,你的代码其实没有内存泄露的。较真的话,你把 ClassA a;这句用 { } 包起来,保证检测不到了,注意理解 作用域 这个概念
请问 __RTC_CheckEsp 这个的作用是什么,之前我发现这个在函数结束前出现一次同时在线程退出前调用@__security_check_cookie@4后又出现了一次,误以为这个就是_CrtDumpMemoryLeaks的检测
赵4老师 2016-09-08
  • 打赏
  • 举报
回复
理解讨论之前请先学会如何观察! 计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构…… 对学习编程者的忠告: 多用小脑和手,少用大脑、眼睛和嘴,会更快地学会编程! 眼过千遍不如手过一遍! 书看千行不如手敲一行! 手敲千行不如单步一行! 单步源代码千行不如单步Debug版对应汇编一行! 单步Debug版对应汇编千行不如单步Release版对应汇编一行! 不会单步Release版对应汇编?在你想单步Release版C/C++代码片断的前面临时加一句DebugBreak();重建所有,然后在IDE中运行。(一般人我不告诉他!单步类的实例“构造”或“复制”或“作为函数参数”或“作为函数返回值返回”或“参加各种运算”或“退出作用域”的语句对应的汇编代码几步后,就会来到该类的“构造函数”或“复制构造函数”或“运算符重载”或“析构函数”对应的C/C++源代码处。 VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。 对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。 a在main的}之后才会被析构。
cutmelon 2016-09-08
  • 打赏
  • 举报
回复
_CrtDumpMemoryLeaks();调用的时候还没有执行delete,你的代码其实没有内存泄露的。较真的话,你把 ClassA a;这句用 { } 包起来,保证检测不到了,注意理解 作用域 这个概念

65,210

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧