您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Qt下如何監測內存泄漏,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
為了預防內存泄漏問題,我們手動寫一個宏,用來監測該類是否析構,若未析構,則將該類打印出來,這樣可以更好的定位問題。代碼如下:
定義一個幫助類,用來計數,當注冊的類聲明時,計數+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下如何監測內存泄漏”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。