您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)Qt下如何監(jiān)測(cè)內(nèi)存泄漏,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
為了預(yù)防內(nèi)存泄漏問(wèn)題,我們手動(dòng)寫(xiě)一個(gè)宏,用來(lái)監(jiān)測(cè)該類是否析構(gòu),若未析構(gòu),則將該類打印出來(lái),這樣可以更好的定位問(wèn)題。代碼如下:
定義一個(gè)幫助類,用來(lái)計(jì)數(shù),當(dāng)注冊(cè)的類聲明時(shí),計(jì)數(shù)+1,當(dāng)類析構(gòu)時(shí),計(jì)數(shù)-1,若在該類析構(gòu)時(shí),計(jì)數(shù)大于0,則該注冊(cè)的類未析構(gòu),則打印出來(lái),提示開(kāi)發(fā)者出現(xiàn)內(nèi)存泄漏問(wèn)題,告訴是哪個(gè)類未析構(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局部變量的生存周期,當(dāng)程序退出時(shí),靜態(tài)局部變量析構(gòu),此時(shí)CountCheckerHelper析構(gòu),若此時(shí)注冊(cè)的類的計(jì)數(shù)大于0,則證明該注冊(cè)的類內(nèi)存泄漏,將該宏寫(xiě)入到你的類的如下位置,其實(shí)就是聲明一個(gè)內(nèi)部類,并創(chuàng)建這個(gè)內(nèi)部類的對(duì)象。
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)測(cè)內(nèi)存泄漏”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。