当前位置:首页 > 公众号精选 > CPP开发者
[导读]Windows中内存泄露的文章已经写过两篇>"data-itemshowtype="11"tab="innerlink"data-linktype="2">和>"data-itemshowtype="11"tab="innerlink"data-linktype="2">。如果有...

Windows内存泄露的文章已经写过两篇>" data-itemshowtype="11" tab="innerlink" data-linktype="2"><>和>" data-itemshowtype="11" tab="innerlink" data-linktype="2"><<Windows程序内存泄漏(Memory Leak)分析之Windbg>>。如果有丰富调试经验的同学会发现,很难用一种工具或者方法去分析所有的场景,尤其当工程庞大的时候。本文要介绍的就是微软提供的DebugDialog, 他可以用于分析Hang,性能问题,内存泄露问题等等。对于内存泄露问题,DebugDialog分析后会给出一个完整的Report,免去了你通过Windbg命令去分析内存的过程,适合于新人。

样例代码

按照惯例我们先写了一段内存泄露的代码,每隔20秒,造成4M内存泄露。

#include 
#include 
#include 

#define STR_SIZE 4*1024*1024
class TestClass
{

public:
    char m_str[STR_SIZE];
};

void MemoryLeakObj()
{
    TestClass * pObj = new TestClass;
    strcpy_s(pObj->m_str, STR_SIZE, "Memory Leak Sample");
    std::cout << pObj->m_str << std::endl;
}

int main()
{
    std::this_thread::sleep_for(std::chrono::seconds(30));
    while (true)
    {
        MemoryLeakObj();
        std::this_thread::sleep_for(std::chrono::seconds(20));
    }
    return 0;
}

DebugDialog内存泄露分析

第一步 打开DebugDialog Collection,选择你需要分析的问题的类型,比如我们想要分析的是Native Memory and Handle Leak问题。

第二步 选择你需要Monitor的正在运行的进程:

第三步 选择你需要产生Dump的时间,最少要配置15分钟,这个可以根据你项目产生Memory Leak的速度来决定。

第四步 然后Active你配置的Rule,则需要监测的进程被注入LeakTrack.dll用于辅助分析。接下来静心等待,直到产生了Dump文件。
第五步 开启DebugDialog Analysis, 先配置好符号文件目录:

然后选择MemoryAnalysis, 并且添加刚才Monitor后产生的Dump文件。点击Start Analysis进行分析。

DebugDialog 内存泄露报告分析

报告主要分为四个个部分,SummaryVirtual Memory AnalysisHeap AnalysisLeak Analysis

Summary

这里主要大概介绍内存申请的来源,比如下面ucrtbase.dll申请了180多M,那么可以知道这个程序内存泄露主要通过CRT库申请的内存泄露,也就是mallocnew。那么是哪里申请的呢?具体可以看Leak Analysis这一部分。 

Virtual Memory Analysis

这一部分主要讲了虚拟内存的使用情况, 主要着重看下Committed MemoryNative Heaps,约为200M左右。也就是说主要是堆上消耗的内存比较多,一般来说内存泄露也是堆内存泄露。其他的还有可以直接通过VirtualAlloc,Memory Map等技术去使用内存。
这部分还会显示加载的一些模块基本信息,线程基本信息。

Heap Analysis

一个进程可以有多个堆,我们使用的是VS2015编译的,CRT库中malloc申请内存使用的是系统默认堆(Default Process Heap)。注意到其已经提交了197.81M的内存。

Leak Analysis

这一部分才是内存泄露的关键部分,会列出详细的内存申请的位置和大小。首先注意查看的是Leak Probability 显示为100%, 非常值得怀疑的部分,其列举了申请内存为4M的函数调用栈,可以根据函数调用栈(d:\test\test\memoryleak\source.cpp @ 24 a)寻找到内存泄露的地方。

发送关键字 内存泄漏 获取内存泄漏系列文章


- EOF -

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

据韩联社报道,上周三星电子发布业绩报告显示,随着芯片价格反弹,预计今年第一季度营业利润同比骤增931.25%,为6.6万亿韩元(当前约合人民币354.6亿元),已经超过了2023年全年营业利润6.57万亿韩元。

关键字: 内存 三星

TDK 株式会社(TSE:6762)进一步扩充 Micronas 嵌入式电机控制器系列 HVC 5x,完全集成电机控制器与 HVC-5222D 和 HVC-5422D,以驱动小型有刷(BDC)、无刷(BLDC)或步进电机...

关键字: 嵌入式 电机控制器 内存

Apr. 04, 2024 ---- TrendForce集邦咨询针对403震后各半导体厂动态更新,由于本次地震大多晶圆代工厂都位属在震度四级的区域,加上台湾地区的半导体工厂多以高规格兴建,内部的减震措施都是世界顶尖水平...

关键字: 晶圆代工 内存

好用、高效的多合一传感器开发工具,支持给新一代高科技 MEMS 传感器产品开发应用软件

关键字: 传感器 Windows MacOS

美光坚持多元、平等、包容的企业文化,携手社区推行公益

关键字: 内存 存储 美光

今天,小编将在这篇文章中为大家带来虚拟内存的有关报道,通过阅读这篇文章,大家可以对虚拟内存具备清晰的认识,主要内容如下。

关键字: 内存 虚拟内存

双系统将是下述内容的主要介绍对象,通过这篇文章,小编希望大家可以对双系统的相关情况以及信息有所认识和了解,详细内容如下。

关键字: 双系统 Windows Linux

在这篇文章中,小编将对虚拟内存的相关内容和情况加以介绍以帮助大家增进对它的了解程度,和小编一起来阅读以下内容吧。

关键字: 内存 虚拟内存

以下内容中,小编将对物理内存的相关内容进行着重介绍和阐述,希望本文能帮您增进对物理内存的了解,和小编一起来看看吧。

关键字: 内存 物理内存

美光 LPDDR5X 和 UFS 4.0 以高带宽、高能效以及大容量助力荣耀人工智能创新

关键字: AI 内存 存储 智能手机
关闭
关闭