在写Qt应用程序时,由于是采用C++语言,经常会碰到一个令人棘手的问题,那就是内存泄漏,本文主要介绍了Qt下监测内存泄漏的方法,感兴趣的可以了解一下
在写Qt应用程序时,由于是采用C++语言,经常会碰到一个令人棘手的问题,那就是内存泄漏,虽然后面C++为了防止内存泄漏,发布了智能指针以用来避免内存泄漏,但是并不能完全避免。而且智能指针使用不当,同样会造成非常严重的问题。这里智能指针就不在赘述,有机会我再写篇智能指针的博客。
为了预防内存泄漏问题,我们手动写一个宏,用来监测该类是否析构,若未析构,则将该类打印出来,这样可以更好的定位问题。代码如下:
定义一个帮助类,用来计数,当注册的类声明时,计数+1,当类析构时,计数-1,若在该类析构时,计数大于0,则该注册的类未析构,则打印出来,提示开发者出现内存泄漏问题,告诉是哪个类未析构
class CountCheckerHelper
{
public:
CountCheckerHelper(const char *className, const char *fileName)
: m_className(className)
, m_fileName(fileName)
, m_refCount(0)
{
}
~CountCheckerHelper()
{
if (m_refCount > 0)
{
qDebug() << m_fileName << m_className << "is not delete...";
}
}
void operator ++()
{
++m_refCount;
}
void operator --()
{
--m_refCount;
}
private:
const char *m_className;
const char *m_fileName;
unsigned int m_refCount;
};
#define CAPTURE_MEMORY_LEAK(ClassName) \
class CountChecker \
{ \
public: \
CountChecker() \
{ \
++counter(); \
} \
~CountChecker() \
{ \
--counter(); \
} \
private: \
CountCheckerHelper &counter() \
{ \
static CountCheckerHelper instance(#ClassName, __FILE__);\
return instance; \
} \
} countChecker; \
利用static局部变量的生存周期,当程序退出时,静态局部变量析构,此时CountCheckerHelper析构,若此时注册的类的计数大于0,则证明该注册的类内存泄漏,将该宏写入到你的类的如下位置,其实就是声明一个内部类,并创建这个内部类的对象。
class Object
{
CAPTURE_MEMORY_LEAK(Object)
public:
Object()
{
}
};
int main()
{
Object *object = new Object();
return 0;
}
结果:打印出内存泄漏的文件,以及泄漏的类名Object
到此这篇关于Qt下监测内存泄漏的方法的文章就介绍到这了,更多相关Qt 监测内存泄漏内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:Qt下监测内存泄漏的方法


- C语言详解float类型在内存中的存储方式 2023-03-27
- c++ const 成员函数,返回一个 const 指针.但是返回的指针是什么类型的 const? 2022-10-11
- 详解C语言中sizeof如何在自定义函数中正常工作 2023-04-09
- ubuntu下C/C++获取剩余内存 2023-09-18
- 我应该为我的项目使用相对包含路径,还是将包含目录放在包含路径上? 2022-10-30
- C语言qsort()函数的使用方法详解 2023-04-26
- C++ 数据结构超详细讲解顺序表 2023-03-25
- Qt计时器使用方法详解 2023-05-30
- Easyx实现扫雷游戏 2023-02-06
- C语言手把手带你掌握带头双向循环链表 2023-04-03