有了它,再也不怕?C ?內(nèi)存泄露了!
C/C 程序越復雜,內(nèi)存的管理顯得越重要,稍有不慎就會出現(xiàn)泄漏。如果內(nèi)存泄漏不是很嚴重,在短時間內(nèi)對程序不會有太大影響,這也使得內(nèi)存泄漏問題有很強的隱蔽性,不易被發(fā)現(xiàn)。
然而不管內(nèi)存泄漏多么輕微,當程序長時間運行時,其破壞力是驚人的 - 從性能下降到內(nèi)存耗盡,甚至會影響其他程序的正常運行。
1VLD 簡介
VLD(全稱:Visual Leak Detector)是一款用于 Visual C 的免費內(nèi)存泄露檢測工具。與其它內(nèi)存檢測工具相比,它在檢測到內(nèi)存泄漏的同時,還具有如下特點:
- 可得到內(nèi)存泄漏點的調(diào)用堆棧,以及其所在文件及行號;
- 可得到泄露內(nèi)存的完整數(shù)據(jù);
- 可設(shè)置內(nèi)存泄露報告的級別;
- 提供了打包好的 lib 庫,使用時無須編譯源碼,直接使用即可;
- 源碼使用 GNU 許可發(fā)布,并有詳盡的文檔及注釋。對于想深入了解堆內(nèi)存管理的讀者,是一個不錯的選擇。
VLD 簡單易用,只需要添加庫并包含頭文件,然后正常運行自己的程序,就可以發(fā)現(xiàn)內(nèi)存問題了;如果深入源碼,可以學習到堆內(nèi)存分配與釋放的原理、內(nèi)存泄漏檢測的原理、以及內(nèi)存操作的常用技巧等。
2下載安裝
- VLD 主頁:https://kinddragon.github.io/vld/
- 文檔地址:https://github.com/KindDragon/vld/wiki
- GitHub 地址:https://github.com/KindDragon/vld
進入主頁后,點擊右上角的“Download Installer”按鈕,下載 VLD 安裝程序(目前版本:vld-xxx-setup.exe):
下載完成之后,進行傻瓜式安裝(下一步 ......下一步),安裝后的目錄如下所示:
其中,各目錄及其內(nèi)容為:
- bin:包含了運行時的庫文件 - dbghelp.dll、vld_x64.dll
- include:包含了編譯時要用到的頭文件 - vld.h、vld_def.h
- lib:包含了編譯時要用到的庫文件 - vld.lib
3使用方法
新建一個 C 控制臺程序:
#include?
int?main()
{
????int?*a?=?new?int[10];
????return?0;
}
然后,配置項目:
- 附加包含目錄:D:\Program Files\Visual Leak Detector\include
- 附加庫目錄:D:\Program Files\Visual Leak Detector\lib\Win64
- 附加依賴項:vld.lib
截止目前,VLD 最高支持到 VS 2015,在 VS 2019 中沒有太多有關(guān)內(nèi)存泄漏的信息,可以在屬性設(shè)置中做相關(guān)配置:
在 Debug 模式下運行程序,VLD 會輸出內(nèi)存泄漏報告,其中包含了完整的調(diào)用堆棧:
看到了吧,提示第 5 行出現(xiàn)了內(nèi)存泄漏。
還等什么,抓緊時間解決啦:
#include?
int?main()
{
????int?*a?=?new?int[10];
????delete[]a;
????return?0;
}
再次運行程序,內(nèi)存泄漏已經(jīng)不見了:
4工作原理
想必到這里,很多小伙伴都對 VLD 的工作原理感興趣,其實它的主要工作分了三步:
- 在初始化時注冊一個鉤子函數(shù);
- 在內(nèi)存分配時,該鉤子函數(shù)會被調(diào)用,以記錄當時的現(xiàn)場;
- 檢查堆內(nèi)存分配鏈表,以確定是否存在內(nèi)存泄漏,并將泄漏內(nèi)存的現(xiàn)場轉(zhuǎn)換成可讀的形式輸出。
如果對細節(jié)實現(xiàn)感興趣,建議研究一下 VLD 的源碼。
- EOF -