zoukankan      html  css  js  c++  java
  • vs 2017/2015/2013 如何定位C++内存泄漏

    定位内存泄漏是C++的一个大问题

    我们可以通过如下方式进行定位:

    复制代码
    //在主函数文件中加入如下代码
    
    #include <stdlib.h>  
    #include <crtdbg.h>  
      
      
    #ifdef _DEBUG  
    #define new new(_NORMAL_BLOCK, __FILE__, __LINE__)  
    #endif  
      
    void EnableMemLeakCheck()  
    {  
        int tmpFlag = _CrtSetDbgFlag(_CRTDBG_REPORT_FLAG);  
        tmpFlag |= _CRTDBG_LEAK_CHECK_DF;  
        _CrtSetDbgFlag(tmpFlag);  
    }  
      
    using namespace std;  
    int main()  
    {  
        EnableMemLeakCheck();  
        //_CrtSetBreakAlloc(这里有第一遍注释掉, 第二遍再执行);  
            自己的代码  
    }  
    复制代码

    在 debug 模式下,可以看到如下信息:

     此时我们注意大括号的内容,这就是可以我们的程序内存泄漏的地方。

    将上面注释掉的代码加入,并将大括号的数字填入,就可以让程序停在内存泄漏的地方。

    如下,这里我们让程序停在 556 处

    复制代码
    //在主函数文件中加入如下代码
    
    #include <stdlib.h>  
    #include <crtdbg.h>  
      
      
    #ifdef _DEBUG  
    #define new new(_NORMAL_BLOCK, __FILE__, __LINE__)  
    #endif  
      
    void EnableMemLeakCheck()  
    {  
        int tmpFlag = _CrtSetDbgFlag(_CRTDBG_REPORT_FLAG);  
        tmpFlag |= _CRTDBG_LEAK_CHECK_DF;  
        _CrtSetDbgFlag(tmpFlag);  
    }  
      
    using namespace std;  
    int main()  
    {  
        EnableMemLeakCheck();  
        //_CrtSetBreakAlloc(556);  
            自己的代码  
    }  
    复制代码

    参考:http://blog.csdn.net/dyx810601/article/details/52092835

  • 相关阅读:
    BZOJ1513: [POI2006]Tet-Tetris 3D
    BZOJ3210: 花神的浇花集会
    BZOJ3207: 花神的嘲讽计划Ⅰ
    BZOJ3170: [Tjoi 2013]松鼠聚会
    BZOJ3747: [POI2015]Kinoman
    解题:POI 2008 Subdivision of Kingdom
    解题:JSOI 2007 重要的城市
    解题:USACO13NOV No Change
    解题:洛谷1120 小木棍
    解题:SCOI 2008 配对
  • 原文地址:https://www.cnblogs.com/lidabo/p/9429075.html
Copyright © 2011-2022 走看看