VisualStudio 使用Visual Leak Detector檢查內(nèi)存泄漏
那么在Windows下有什么好的內(nèi)存泄漏檢測工具呢?微軟提供Visual Studio開發(fā)工具本身沒有什么太好的內(nèi)存泄漏檢測功能,我們可以使用第三方工具Visual Leak Detector(以下簡稱vld)。
vld工具是VC++環(huán)境下一款小巧易用、免費(fèi)開源的內(nèi)存泄漏檢測工具,vld可以顯示導(dǎo)致內(nèi)存泄漏的完整內(nèi)存分配調(diào)用堆棧。vld的檢測報告能夠?qū)γ總€內(nèi)存泄漏點提供完整的堆棧跟蹤,并且包含其源文件及行號信息。
安裝過程是,先在到地址http://vld.codeplex.com/下載vld安裝文件,然后進(jìn)行安裝,安裝過程中需要安裝程序會配置環(huán)境變量。我們需要記住安裝目錄。
安裝完成后打開要檢測的Visual Studio工程,我們需要在工程中配置:vld頭文件目錄和vld庫目錄。
選中游戲工程,打開菜單“項目”→ “屬性”彈出工程屬性對話框,如圖所示,選擇“配置屬性”→“VC++目錄” →“常規(guī)”,在右邊的“包含目錄”中添加C:\Program Files (x86)\Visual Leak Detector\include,其中C:\Program Files (x86)\Visual Leak Detector是我的vld安裝目錄?!皫炷夸洝敝刑砑覥:\Program Files (x86)\Visual Leak Detector\lib\Win32,注意配置目之間需要用分號分隔開。
配置完成之后點擊確定按鈕關(guān)閉對話框,然后我們需要在程序代碼中引入頭文件#include <vld.h>,但是這個頭文件在哪里引入比較好?如果是普通的一個VC++工程在哪里引入都無所謂,但是Cocos2d-x的工程就不同了,我們需要考慮跨平臺,#include <vld.h>代碼不宜添加到Classes目錄下的h或cpp文件中,這個目錄下的文件是要在其它平臺編譯運(yùn)行的,而#include <vld.h>只是在Windrows平臺才有效。我們可以在Win32目錄(見圖)下的main.cpp或main.h文件引入頭文件。這些文件是與Win32平臺有關(guān)的,不同平臺移植的時候不需要。
如果在main.cpp中引入代碼如下:
#include "main.h" #include "AppDelegate.h" #include "cocos2d.h" #include <vld.h> USING_NS_CC; int APIENTRY _tWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPTSTR lpCmdLine, int nCmdShow) { UNREFERENCED_PARAMETER(hPrevInstance); UNREFERENCED_PARAMETER(lpCmdLine); // create the application instance AppDelegate app; return Application::getInstance()->run(); }
引入之后,就測試一下了,我們來人為制造一個內(nèi)存泄漏,與20.1.1一節(jié)一樣在HelloWorldScene.cpp中修改代碼:
bool HelloWorld::init() { if ( !Layer::init() ) { return false; } __String *s = new __String(); log("%s",s->getCString()); … … return true; }
運(yùn)行工程,需要注意的是在程序運(yùn)行過程中vld是沒有堆棧輸出的,但是日志會有輸出vld的安裝信息,日志信息如下:
Visual Leak Detector Version 2.4RC2 installed.
Ready for GLSL
Ready for OpenGL 2.0
… …
從日志中可以看到vld是否安裝成功,以及安裝的版本。要想看到vld檢測報告需要退出程序后,才會在日志中輸出信息。使用Cocos2d-x會輸出很多日志信息,信息如下:
---------- Block 526166 at 0x0821FA80: 84 bytes ---------- Leak Hash: 0x780B2033, Count: 1, Total 84 bytes Call Stack (TID 4660): ... ... ---------- Block 526214 at 0x08224378: 8 bytes ---------- Leak Hash: 0xE1DC1852, Count: 1, Total 8 bytes Call Stack (TID 4660): ... ... Data: 63 6F 63 6F 73 32 64 20 61 75 74 6F 72 65 6C 65 cocos2d. autorele 61 73 65 20 70 6F 6F 6C 00 CD CD CD CD CD CD CD ase.pool ........ Visual Leak Detector detected 33 memory leaks (2892 bytes). Largest number used: 3204961 bytes. Total allocations: 69022415 bytes. Visual Leak Detector is now exiting.
其中一個Block表示一個內(nèi)存泄漏點,在眾多Block如果能夠找到關(guān)于我們自己類的日志信息呢?我們可以查找關(guān)鍵字“helloworldscene.cpp”,這就可以定位到HelloWorld場景中的內(nèi)存泄漏的Block了,我們找到如下日志信息:
---------- Block 1153 at 0x01533C70: 48 bytes ---------- Leak Hash: 0x5545A5ED, Count: 1, Total 48 bytes Call Stack (TID 2088): f:\dd\vctools\crt_bld\self_x86\crt\src\new.cpp (57): MSVCR110D.dll!operator new d:\helloworld\classes\helloworldscene.cpp (33): HelloWorld.exe!HelloWorld::init + 0x7 bytes d:\helloworld\classes\helloworldscene.h (37): HelloWorld.exe!HelloWorld::create + 0xB1 bytes d:\helloworld\classes\helloworldscene.cpp (12): HelloWorld.exe!HelloWorld::createScene + 0x5 bytes d:\helloworld\classes\appdelegate.cpp (30): HelloWorld.exe!AppDelegate::applicationDidFinishLaunching + 0x5 bytes d:\helloworld\cocos2d\cocos\2d\platform\win32\ccapplication.cpp (74): HelloWorld.exe!cocos2d::Application::run + 0xF bytes d:\helloworld\proj.win32\main.cpp (19): HelloWorld.exe!wWinMain + 0xC bytes f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c (528): HelloWorld.exe!__tmainCRTStartup + 0x15 bytes f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c (377): HelloWorld.exe!wWinMainCRTStartup 0x7563850D (File and line number not available): KERNEL32.DLL!BaseThreadInitThunk + 0xE bytes 0x77B7BF39 (File and line number not available): ntdll.dll!RtlInitializeExceptionChain + 0x85 bytes 0x77B7BF0C (File and line number not available): ntdll.dll!RtlInitializeExceptionChain + 0x58 bytes Data: 1C 34 07 01 01 00 00 00 27 00 00 00 00 00 00 00 .4...... '....... 2C 34 07 01 A0 77 01 03 00 CD CD CD CD CD CD CD ,4...w.. ........ CD CD CD CD CD CD CD CD 00 00 00 00 0F 00 00 00 ........ ........
從這個日志中能看到內(nèi)存泄漏點,從日志的堆棧中找到我們自己編寫的類,點擊那一行打開代碼窗口,定位內(nèi)存泄漏點代碼,如圖所示。
定位內(nèi)存泄漏點
找到哪一個有可能有內(nèi)存泄漏,解決就不是問題了。
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
上一篇:c++線程池實現(xiàn)方法
欄 目:C語言
下一篇:C++之類的靜態(tài)變量
本文標(biāo)題:VisualStudio 使用Visual Leak Detector檢查內(nèi)存泄漏
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/3010.html
您可能感興趣的文章
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 01-10使用OpenGL實現(xiàn)3D立體顯示的程序代碼
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10深入Main函數(shù)中的參數(shù)argc,argv的使用詳解
- 01-10C++大數(shù)模板(推薦)
- 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解
- 01-10基于C語言fflush()函數(shù)的使用詳解
- 01-10linux c 查找使用庫的cflags與libs的方法詳解
- 01-10深入sizeof的使用詳解
- 01-10基于c中使用ftruncate()前需要fflush(),使用后需要rewind()的深入探討


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10C#中split用法實例總結(jié)
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery
- 08-05織夢dedecms什么時候用欄目交叉功能?