Qt下監(jiān)測內(nèi)存泄漏的方法
在寫Qt應(yīng)用程序時,由于是采用C++語言,經(jīng)常會碰到一個令人棘手的問題,那就是內(nèi)存泄漏,雖然后面C++為了防止內(nèi)存泄漏,發(fā)布了智能指針以用來避免內(nèi)存泄漏,但是并不能完全避免。而且智能指針使用不當,同樣會造成非常嚴重的問題。這里智能指針就不在贅述,有機會我再寫篇智能指針的博客。
??? 為了預防內(nèi)存泄漏問題,我們手動寫一個宏,用來監(jiān)測該類是否析構(gòu),若未析構(gòu),則將該類打印出來,這樣可以更好的定位問題。代碼如下:
定義一個幫助類,用來計數(shù),當注冊的類聲明時,計數(shù)+1,當類析構(gòu)時,計數(shù)-1,若在該類析構(gòu)時,計數(shù)大于0,則該注冊的類未析構(gòu),則打印出來,提示開發(fā)者出現(xiàn)內(nèi)存泄漏問題,告訴是哪個類未析構(gòu)
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局部變量的生存周期,當程序退出時,靜態(tài)局部變量析構(gòu),此時CountCheckerHelper析構(gòu),若此時注冊的類的計數(shù)大于0,則證明該注冊的類內(nèi)存泄漏,將該宏寫入到你的類的如下位置,其實就是聲明一個內(nèi)部類,并創(chuàng)建這個內(nèi)部類的對象。
class Object
{
CAPTURE_MEMORY_LEAK(Object)
public:
Object()
{
}
};
int main()
{
Object *object = new Object();
return 0;
}
結(jié)果:打印出內(nèi)存泄漏的文件,以及泄漏的類名Object
?
到此這篇關(guān)于Qt下監(jiān)測內(nèi)存泄漏的方法的文章就介紹到這了,更多相關(guān)Qt 監(jiān)測內(nèi)存泄漏內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

