在寫Qt應用程序時,由于是采用C++語言,經常會碰到一個令人棘手的問題,那就是內存泄漏,雖然后面C++為了防止內存泄漏,發布了智能指針以用來避免內存泄漏,但是并不能完全避免。而且智能指針使用不當,同樣會造成非常嚴重的問題。這里智能指針就不在贅述,有機會我再寫篇智能指針的博客。
為了預防內存泄漏問題,我們手動寫一個宏,用來監測該類是否析構,若未析構,則將該類打印出來,這樣可以更好的定位問題。代碼如下:
定義一個幫助類,用來計數,當注冊的類聲明時,計數+1,當類析構時,計數-1,若在該類析構時,計數大于0,則該注冊的類未析構,則打印出來,提示開發者出現內存泄漏問題,告訴是哪個類未析構
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
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,則證明該注冊的類內存泄漏,將該宏寫入到你的類的如下位置,其實就是聲明一個內部類,并創建這個內部類的對象。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
class Object { CAPTURE_MEMORY_LEAK(Object) public : Object() { } }; int main() { Object *object = new Object(); return 0; } |
結果:打印出內存泄漏的文件,以及泄漏的類名Object
到此這篇關于Qt下監測內存泄漏的方法的文章就介紹到這了,更多相關Qt 監測內存泄漏內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/yinyuchen1/article/details/121757439