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 監測內存泄漏內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!