zoukankan      html  css  js  c++  java
  • windows内存debug技巧


    A) c++ memory/heap corrupt debug 技巧

    1. catch first exception
    2. data breakpoint
    VC tell us some address is corrupt when free some pointer
    Check which pointer it is
    Set break point when malloc the pointer
    Set data breakpoint at the corrupt address after the pointer is malloc
    VC will break at the place which corrupts memory

    3. application verifier heap check 功能
    4.



    B) c++ memory leakage
    注:需要管理员权限(gflags需要),能上网(会自动下载symbols)

    主要有几个需求
    一是dump leakage,可以用1,3实现
    二是显示leakage的call stack,可以用1,2实现
    而2的用法是比较两次快照,1可以在程序退出时做

    1. windbg
    set _NT_SYMBOL_PATH=SRV*C:MyLocalSymbols*http://msdl.microsoft.com/download/symbols
    run gflags to enable the stack trace of the program
    start the program
    start windbg and attach to the program
    bm wineagle!_CrtDumpMemoryLeaks
    make the program leak memory
    exit program
    the program will break into windbg
    step out by gu command
    !heap -p -a <ADDR> where ADDR is the dumped leakage address

    2. umdh
    set _NT_SYMBOL_PATH=SRV*C:MyLocalSymbols*http://msdl.microsoft.com/download/symbols
    Gflags to enable OS log stack trace
    restart the debugee program
        -1- umdh.exe -pn:application_name.exe -f:FirstDump.txt
        -2- ... exercise the application
        -3- umdh.exe -pn:application_name.exe -f:SecondDump.txt
        -4- umdh.exe FirstDump.txt SecondDump.txt -f:Result.txt
               Compares allocations from the two dumps.

    3. vc crt lib dump leakage


    C) crt内存结构
    Crt: _CrtSetDbgFlag, _CrtCheckMemory

    D)关于gflags的heap类型
    Gflags:
    Full-page heap: placing a non-accessible page at the end of the allocation
    Normal page heap: It checks fill patterns when a heap block is freed
    Advantage: reduces memory consumption
    Disadvantage


    E) windbg extension
    http://www.codeproject.com/Articles/6522/Debug-Tutorial-Part-4-Writing-WINDBG-Extensions
    http://www.haogongju.net/art/1428822
    ??Debugging Tools for Windows, ?%programfiles% Debugging Tools for Windows (x86)sdk????.

    ??:

    Sdkinc: ?????

    ??Dump???Callstack,??windbg???????

    Sdklib:?????,dbghelp.lib,dbgeng.lib,engextcpp.lib,??????????

    ??Dump???Callstack,??windbg???????

    Sdksamples: samples(???????)
    ??Dump???Callstack,??windbg???????

    Sdkhelp:????

    F)
    Windows Performance Analyzer
    http://msdn.microsoft.com/en-us/library/windows/desktop/ff190971%28v=vs.85%29.aspx
    Write a debugger
    http://social.msdn.microsoft.com/Forums/en-US/netfxbcl/thread/90770a1c-7f83-4f81-864f-e64f3e17d02b
    You can use mdbg as a model for a debugger implementation, it comes with source code and you will find a lot of references about it . Depending on the type of debugging you want to do there are two APIs you can use: - for native applications you should use the native debugging API :爃ttp://msdn.microsoft.com/en-us/library/ms679304(VS.85).aspx
    - for managed applications the managed debugging API :爃ttp://msdn.microsoft.com/en-us/library/ms404520.aspx

    Both come with samples, for example this (http://msdn.microsoft.com/en-us/library/ms679288(VS.85).aspx) is an example of building a basic debugger using the native API. I also recommend Mike Stall's debugging blog爃ttp://blogs.msdn.com/jmstall/default.aspx.
    Creating a Basic Debugger
    http://msdn.microsoft.com/en-us/library/ms679288%28VS.85%29.aspx

    Sample code for PDB 2 XML tool
    http://blogs.msdn.com/b/jmstall/archive/2005/08/25/sample-pdb2xml.aspx
    Tool to get snapshot of managed callstacks
    http://blogs.msdn.com/b/jmstall/archive/2005/11/28/snapshot.aspx




  • 相关阅读:
    【原】error C2679: binary '<<' : no operator found which takes a right-hand operand of type 'std::string'
    【原】开发路上疑难BUG调试记录
    【转】XCode: duplicate symbol 解决方案
    【原】就IOS发布app时如何保护文本资源的一个方法
    【原】xcode5.0升级5.1遇到的clang: error: unknown argument: '-fobj-arc'错误
    【转】生产者与消费者
    安卓快速排序与冒泡排序
    数据结构之算法时间复杂度
    常见数据结构与算法整理总结(上)
    Activity的onPause()、onStop()和onDestroy()里要做的事情
  • 原文地址:https://www.cnblogs.com/cutepig/p/3167999.html
Copyright © 2011-2022 走看看