Qt Visual Leak Detector 输出解析(四)
1. 使用方式
在 QT 中使用 VLD 的方法可以查看另外几篇博客:
- QT 使用 Visual Leak Detector(方式一)
 - QT 使用 Visual Leak Detector(方式二)
 - QT 使用 Visual Leak Detector(方式三)
 
本次测试使用的环境为:QT 5.9.2,Debug 模式,VLD 版本为 2.5.1,VLD 配置文件不做任何更改使用默认配置,测试工程所在路径为:E:\Cworkspace\Qt 5.9\QtDemo\testVLD。
2. 测试代码
写一个有一处内存泄漏的程序,如下:
1 #include <QCoreApplication> 2 #include "vld.h" 3 4 void testFun() 5 9 10 int main(int argc, char *argv[]) 113. 使用 32 bit 编译器时的输出
使用MSVC 2015 32bit编译器,程序运行时,在标准输出窗会输出以下结果:
ptr = 0070a3d0, *ptr = 55345678程序运行结束后,检测到了内存泄漏,VLD 会输出以下报告(本例中出现一处内存泄漏),第 1~3 行显示 VLD 运行状态,第 4~21 行显示泄漏内存的详细信息,第 22~24 行总结此次泄漏情况,第 25 行显示 VLD 退出状态。
1 Visual Leak Detector read settings fr: D:\Program Files (x86)\Visual Leak Detector\vld.ini 2 Visual Leak Detector Version 2.5.1 installed. 3 WARNING: Visual Leak Detector detected memory leaks! 4 Block 1 at 0x0070A3D0: 4 bytes 5 Leak Hash: 0xA7ED883D, Count: 1, Total 4 bytes 6 Call Stack (TID 20672): 7 ucrtbased.dll!malloc() 8 f:\dd\vctools\crt\vcstartup\src\heap\new_scalarpp (19): testVLD.exe!operator new() + 0x9 bytes 9 e:\cworkspace\qt 5.9\qtdemo\testvld\mainpp (6): testVLD.exe!testFun() + 0x7 bytes 10 e:\cworkspace\qt 5.9\qtdemo\testvld\mainpp (16): testVLD.exe!main() 11 f:\dd\vctools\crt\vcstartup\src\startup\exe_cmon.inl (74): testVLD.exe!invoke_main() + 0x1B bytes 12 f:\dd\vctools\crt\vcstartup\src\startup\exe_cmon.inl (264): testVLD.exe!__scrt_cmon_main_seh() + 0x5 bytes 13 f:\dd\vctools\crt\vcstartup\src\startup\exe_cmon.inl (309): testVLD.exe!__scrt_cmon_main() 14 f:\dd\vctools\crt\vcstartup\src\startup\exe_mainpp (17): testVLD.exe!mainCRTStartup() 15 KERNEL32.DLL!BaseThreadInitThunk() + 0x19 bytes 16 ntdll.dll!RtlGetAppContainerNamedObjectPath() + 0x11E bytes 17 ntdll.dll!RtlGetAppContainerNamedObjectPath() + 0xEE bytes 18 Data: 19 78 56 34 55 xV4U.... ........ 20 21 22 Visual Leak Detector detected 1 memory leak (40 bytes). 23 Largest number used: 40 bytes. 24 Total allocations: 40 bytes. 25 Visual Leak Detector is now exiting.4. 使用 64 bit 编译器时的输出
使用MSVC 2015 64bit编译器,程序运行时,在标准输出窗会输出以下结果:
ptr = 25a42da0, *ptr = 55345678程序运行结束后,检测到了内存泄漏,VLD 会输出以下报告(本例中出现一处内存泄漏),第 1~3 行显示 VLD 运行状态,第 4~21 行显示泄漏内存的详细信息,第 22~24 行总结此次泄漏情况,第 25 行显示 VLD 退出状态。
1 Visual Leak Detector read settings fr: D:\Program Files (x86)\Visual Leak Detector\vld.ini 2 Visual Leak Detector Version 2.5.1 installed. 3 WARNING: Visual Leak Detector detected memory leaks! 4 Block 1 at 0x0000000025A42DA0: 4 bytes 5 Leak Hash: 0x92ED96C9, Count: 1, Total 4 bytes 6 Call Stack (TID 16444): 7 ucrtbased.dll!malloc() 8 f:\dd\vctools\crt\vcstartup\src\heap\new_scalarpp (19): testVLD.exe!operator new() + 0xA bytes 9 e:\cworkspace\qt 5.9\qtdemo\testvld\mainpp (6): testVLD.exe!testFun() + 0xA bytes 10 e:\cworkspace\qt 5.9\qtdemo\testvld\mainpp (16): testVLD.exe!main() 11 f:\dd\vctools\crt\vcstartup\src\startup\exe_cmon.inl (75): testVLD.exe!invoke_main() 12 f:\dd\vctools\crt\vcstartup\src\startup\exe_cmon.inl (264): testVLD.exe!__scrt_cmon_main_seh() + 0x5 bytes 13 f:\dd\vctools\crt\vcstartup\src\startup\exe_cmon.inl (309): testVLD.exe!__scrt_cmon_main() 14 f:\dd\vctools\crt\vcstartup\src\startup\exe_mainpp (17): testVLD.exe!mainCRTStartup() 15 KERNEL32.DLL!BaseThreadInitThunk() + 0x14 bytes 16 ntdll.dll!RtlUserThreadStart() + 0x21 bytes 17 Data: 18 78 56 34 55 xV4U.... ........ 19 20 21 Visual Leak Detector detected 1 memory leak (56 bytes). 22 Largest number used: 56 bytes. 23 Total allocations: 56 bytes. 24 Visual Leak Detector is now exiting.5. 输出报告对比结果
使用不同位数的编译器时,输出报告的差异主要体现在以下几点:
- 地址的表示位数不同,32 bit 编译器使用 8 位十六进制数表示,64 bit 编译器使用 16 位十六进制数表示。体现在输出的第 4 行,分别为 0x0070A3D0 和 0x0000000025A42DA0。
 - 程序启动时所调用的 Windows 操作系统函数不完全相同,32 bit 编译器调用了两次 RtlGetAppContainerNamedObjectPath() 函数和一次 BaseThreadInitThunk() 函数,64 bit 编译器只调用了一次 RtlUserThreadStart() 函数和一次 BaseThreadInitThunk() 函数,且它们调用 BaseThreadInitThunk() 函数时泄漏指令的内存偏移量不同,32 bit 编译器是 0x19 bytes,而 64 bit 编译器是 0x14 bytes。
 - 内存管理头的宽度不同,32 bit 编译器时是 36 bytes,64 bit 编译器时是 52 bytes。体现在输出的倒数第二行,分别为 Total allocations: 40 bytes 和 Total allocations: 56 bytes,将代码请求的内存大小 4 bytes 加上各自管理头的内存大小,可以得到与输出一致的结果: 4 + 36 = 40 b y t e s 4 + 36 = 40bytes4+36=40bytes 及 4 + 52 = 56 b y t e s 4 + 52 = 56bytes4+52=56bytes。
 
下一篇:Qt Creator 内存分析
Qt Visual Leak Detector
spc文件怎么看,spc文件用什么打开?
0文件怎么看,0文件用什么打开?
sparseimage文件怎么看,sparseimage文件用什么打开?
sp文件怎么看,sp文件用什么打开?
dv文件怎么看,dv文件用什么打开?
soundpack文件怎么看,soundpack文件用什么打开?
dus文件怎么看,dus文件用什么打开?
dtw文件怎么看,dtw文件用什么打开?
spdf文件怎么看,spdf文件用什么打开?
0文件怎么看,0文件用什么打开?
 
  
  