【cpp/c++ summary 工具】 vld(Visual Leak Detector)windows 内存泄漏检测工具

  • Visual Leak Detector,这是一个用于检测C/C++程序内存泄漏的工具。它可以在开发Windows应用程序时发现并修复内存泄漏的问题。

安装VLD

运行程序

在项目中包含头文件
  • 项目中,通常需要在main.cpp或相应的入口点文件中包含vld.h头文件。这样可以在程序启动时初始化VLD。
// main.cpp 或者项目的入口文件
#include "vld.h"
链接VLD库
  • 如果你使用的是Visual Studio,可以在项目属性中进行如下操作:
  1. 右键打开项目属性页面 (PropertiesAlt + Enter)。
  2. 转到VC++目录 -> 包含目录 添加VLD库的位置。
  3. 转到VC++目录 -> 库目录添加VLD.lib所在目录位置。

在这里插入图片描述

#include "vld.h"  // 引入VLD头文件
#include <iostream>

int main() {
    std::cout << "Starting program..." << std::endl;

    int* p = new int(5);  // 分配内存
    // delete p;             // 释放内存

    std::cout << "Program finished." << std::endl;

    return 0;
}
  • 构建并运行程序。VLD会在程序退出时报告内存泄漏情况。
“testvld.exe”: 已加载“C:\Users\audit\Documents\Visual Studio 2010\Projects\testvld\Debug\testvld.exe”,已加载符号。
“testvld.exe”: 已加载“C:\Windows\SysWOW64\ntdll.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\kernel32.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\KernelBase.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\msvcp100d.dll”,已加载符号。
“testvld.exe”: 已加载“C:\Program Files (x86)\Visual Leak Detector\bin\Win32\vld_x86.dll”,已加载符号。
“testvld.exe”: 已加载“C:\Windows\SysWOW64\msvcr100d.dll”,已加载符号。
“testvld.exe”: 已加载“C:\Windows\SysWOW64\advapi32.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\msvcrt.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\sechost.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\bcrypt.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\rpcrt4.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Program Files (x86)\Visual Leak Detector\bin\Win32\dbghelp.dll”,Cannot find or open the PDB file
Visual Leak Detector read settings from: C:\Program Files (x86)\Visual Leak Detector\vld.ini
Visual Leak Detector Version 2.5.1 installed.
线程 'Win32 线程' (0x3328) 已退出,返回值为 0 (0x0)。
线程 'Win32 线程' (0x2144) 已退出,返回值为 0 (0x0)。
线程 'Win32 线程' (0x29dc) 已退出,返回值为 0 (0x0)。
WARNING: Visual Leak Detector detected memory leaks!
---------- Block 1 at 0x014248D8: 4 bytes ----------
  Leak Hash: 0xFDB1D2BB, Count: 1, Total 4 bytes
  Call Stack (TID 4060):
    MSVCR100D.dll!operator new()
    c:\users\audit\documents\visual studio 2010\projects\testvld\testvld\main1.cpp (7): testvld.exe!main() + 0x7 bytes
    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c (555): testvld.exe!__tmainCRTStartup() + 0x19 bytes
    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c (371): testvld.exe!mainCRTStartup()
    KERNEL32.DLL!BaseThreadInitThunk() + 0x19 bytes
    ntdll.dll!RtlInitializeExceptionChain() + 0x6B bytes
    ntdll.dll!RtlClearBits() + 0xBF bytes
  Data:
    05 00 00 00                                                  ........ ........


Visual Leak Detector detected 1 memory leak (40 bytes).
Largest number used: 40 bytes.
Total allocations: 40 bytes.
Visual Leak Detector is now exiting.
程序“[8448] testvld.exe: 本机”已退出,返回值为 0 (0x0)。

解决内存泄漏

  • 根据VLD提供的报告,检查代码中的内存分配和释放逻辑,以确保所有的newmalloc都有对应的deletefree调用。
#include "vld.h"  // 引入VLD头文件
#include <iostream>

int main() {
    std::cout << "Starting program..." << std::endl;

    int* p = new int(5);  // 分配内存
    // delete p;             // 释放内存

    std::cout << "Program finished." << std::endl;

    return 0;
}
  • 输出:No memory leaks detected.
“testvld.exe”: 已加载“C:\Users\audit\Documents\Visual Studio 2010\Projects\testvld\Debug\testvld.exe”,已加载符号。
“testvld.exe”: 已加载“C:\Windows\SysWOW64\ntdll.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\kernel32.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\KernelBase.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\msvcr100d.dll”,已加载符号。
“testvld.exe”: 已加载“C:\Windows\SysWOW64\msvcp100d.dll”,已加载符号。
“testvld.exe”: 已加载“C:\Program Files (x86)\Visual Leak Detector\bin\Win32\vld_x86.dll”,已加载符号。
“testvld.exe”: 已加载“C:\Windows\SysWOW64\advapi32.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\msvcrt.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\sechost.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\bcrypt.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Windows\SysWOW64\rpcrt4.dll”,Cannot find or open the PDB file
“testvld.exe”: 已加载“C:\Program Files (x86)\Visual Leak Detector\bin\Win32\dbghelp.dll”,Cannot find or open the PDB file
Visual Leak Detector read settings from: C:\Program Files (x86)\Visual Leak Detector\vld.ini
Visual Leak Detector Version 2.5.1 installed.
线程 'Win32 线程' (0xcd0) 已退出,返回值为 0 (0x0)。
线程 'Win32 线程' (0x3ca0) 已退出,返回值为 0 (0x0)。
线程 'Win32 线程' (0x3738) 已退出,返回值为 0 (0x0)。
No memory leaks detected.
Visual Leak Detector is now exiting.
程序“[10956] testvld.exe: 本机”已退出,返回值为 0 (0x0)。
Visual Leak Detector是一款用于Visual C++的免费的内存泄露检测工具。相比较其它的内存泄露检测工具,它在检测到内存泄漏的同时,还具有如下特点: 1、 可以得到内存泄漏点的调用堆栈,如果可以的话,还可以得到其所在文件及行号; 2、 可以得到泄露内存的完整数据; 3、 可以设置内存泄露报告的级别; 4、 它是一个已经打包的lib,使用时无须编译它的源代码。而对于使用者自己的代码,也只需要做很小的改动; 5、 他的源代码使用GNU许可发布,并有详尽的文档及注释。对于想深入了解堆内存管理的读者,是一个不错的选择。 可见,从使用角度来讲,Visual Leak Detector简单易用,对于使用者自己的代码,唯一的修改是#include Visual Leak Detector的头文件后正常运行自己的程序,就可以发现内存问题。从研究的角度来讲,如果深入Visual Leak Detector源代码,可以学习到堆内存分配与释放的原理、内存泄漏检测的原理及内存操作的常用技巧等。 下面让我们来介绍如何使用这个小巧的工具。 首先解压得到vld.h, vldapi.h, vld.lib, vldmt.lib, vldmtdl l.lib, dbghelp.dll等文件。将.h文件拷贝到Visual C++的默认include目录下,将.lib文件拷贝到Visual C++的默认lib目录下,便安装完成了。因为版本问题,如果使用windows 2000或者以前的版本,需要将dbghelp.dll拷贝到你的程序的运行目录下,或其他可以引用到的目录。 接下来需要将其加入到自己的代码中。方法很简单,只要在包含入口函数的.cpp文件中包含vld.h就可以。如果这个cpp文件包含了stdafx.h,则将包含vld.h的语句放在stdafx.h的包含语句之后,否则放在最前面。如下是一个示例程序: #include
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值