• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            酸菜豬蹄的程序人生
            木下編程屯屯燙燙

            MiniDumpWriteDump是MS DbgHelp.dll 中一個API, 用于導出當前運行的程序的Dump. 這個dll程序系統(tǒng)中就有, 但是很多軟件, 都在自己的安裝目錄下保存了這個.dll的最新的版本.

            為了測試這個API, 參考網(wǎng)上一些資料, 寫了一個簡單的C++ 程序. 目的是當有異常發(fā)生的時候, 自動生成Dump文件供之后的分析. 有了Dump文件, 我們就可以使用WinDBG等調(diào)試器來分析異常發(fā)生時的情況. 其實這個功能很多軟件都有, 比如QQ, 魔獸世界, 等等. 它們在出現(xiàn)了異常的時候會彈出一個對話框, 讓用戶輸入異常發(fā)生時的情況, 然后把異常的dump文件用email發(fā)回, 供開發(fā)者們分析修改bug.

            不過有一點, 這里需要程序的調(diào)試符號文件(pdb文件). 對于Debug版來說, 是生成的, 但是Release版來說默認是不生成的. 可以設(shè)置VC的編譯器, 讓它在Release版的時候也生成調(diào)試信息. 這帶來一個新的問題, 因為.pdb里面是保存了源文件的信息的, 為了避免泄密, 可以采用VS中的CVPack工具, 從中去除敏感的信息.

            程序需要使用Dbghelp.hDbghelp.lib . 它們可以從MSDN找到.

            //最主要的函數(shù), 生成Dump
            static void DumpMiniDump(HANDLE hFile, PEXCEPTION_POINTERS excpInfo)
            {
            if (excpInfo == NULL) //如果沒有傳入異常, 比如是在程序里面調(diào)用的, 生成一個異常
            {
            // Generate exception to get proper context in dump
            __try
            {
            OutputDebugString(_T("raising exception\r\n"));
            RaiseException(EXCEPTION_BREAKPOINT, 0, 0, NULL);
            }
            __except(DumpMiniDump(hFile, GetExceptionInformation()),
            EXCEPTION_CONTINUE_EXECUTION)
            {
            }
            }
            else
            {
            OutputDebugString(_T("writing minidump\r\n"));
            MINIDUMP_EXCEPTION_INFORMATION eInfo;
            eInfo.ThreadId = GetCurrentThreadId(); //把需要的信息添進去
            eInfo.ExceptionPointers = excpInfo;
            eInfo.ClientPointers = FALSE;

                // 調(diào)用, 生成Dump. 98不支持
            // Dump的類型是小型的, 節(jié)省空間. 可以參考MSDN生成更詳細的Dump
            .
            MiniDumpWriteDump(
            GetCurrentProcess(),
            GetCurrentProcessId(),
            hFile,
            MiniDumpNormal,
            excpInfo ? &eInfo : NULL,
            NULL,
            NULL);
            }
            }

            下面的是程序部分:

            int _tmain(int argc, _TCHAR* argv[])
            {
            // 創(chuàng)建一個Dump文件
            HANDLE hFile = CreateFile( _T("MiniDump.dmp"), GENERIC_READ | GENERIC_WRITE,
            0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL );
            int code;
            __try
            {   
            // 把自己實現(xiàn)的main函數(shù)包裝一下, 放在try .. except 塊中. 這樣出現(xiàn)了異常可以自動生成dump
            main_wrapper(argc, argv);
            }
            __except( code=GetExceptionCode(), DumpMiniDump(hFile, GetExceptionInformation() ),       EXCEPTION_EXECUTE_HANDLER ) //出現(xiàn)了異常, 記錄異常的code, 生成dump!!
            {
            printf("%x\n", code);
            wchar_t msg[512];
            wsprintf(msg, L"Exception happened. Exception code is %x", code);
            MessageBox(NULL, msg, L"Exception", MB_OK); //顯示消息給用戶
            }
            CloseHandle( hFile ); //關(guān)閉Dump文件
            getchar();
            return 0;
            }

            最下面是兩個測試的函數(shù), main_wrapper函數(shù)將調(diào)用test1, test1將會生成一個異常(非法內(nèi)存寫)

            void test1() {
            int *p;
            p = (int*)0x100;
            *p = 0; //寫0x100地址, 這個是非法的
            }

            void main_wrapper(int argc, _TCHAR* argv[]) {
            test1();
            }

            運行, 異常被捕獲了:

            同時, dump文件也生成了:


            用WinDBG打開Dump文件, 可以清楚的看出異常出現(xiàn)的情況:




            從中可以比較清楚的看到異常發(fā)生的情況(Exception code), 異常出現(xiàn)的地址(test1函數(shù), 偏移0x28). 因為這次測試的是Debug版, 有保存了源代碼的.pdb文件, 所以WinDbg把源代碼也列出來了. 這樣可以非常容易的發(fā)現(xiàn)問題.

            ============================================

            參考:
            DbgHelp中的DumpAPI例子: http://www.debuginfo.com/examples/src/effminidumps/MiniDump.cpp
            CrashReport: 程序出現(xiàn)異常的時候顯示發(fā)送錯誤的對話框, 并把Dump文件發(fā)送到指定的地址. http://code.google.com/p/crashrpt/
            XCrashReport: 與上面的類似的一個開源項目. http://www.codeproject.com/KB/debug/XCrashReportPt1.aspx
            posted on 2010-11-16 10:41 cooelaf 閱讀(2726) 評論(1)  編輯 收藏 引用 所屬分類: Win32
            Comments
             
            久久棈精品久久久久久噜噜| 品成人欧美大片久久国产欧美... 品成人欧美大片久久国产欧美 | 欧美久久精品一级c片片| 色狠狠久久综合网| 性高湖久久久久久久久AAAAA| 久久国产精品国语对白| 99久久99久久精品国产片果冻 | 久久91这里精品国产2020| 亚洲综合精品香蕉久久网97| 97久久超碰成人精品网站| 99久久精品国产麻豆| 精品999久久久久久中文字幕| 久久精品www| 久久久久亚洲精品男人的天堂| 久久久久亚洲爆乳少妇无| 国产精品久久久香蕉| 久久夜色精品国产网站| 久久亚洲欧美日本精品| 人妻中文久久久久| 人人狠狠综合久久88成人| 99久久无色码中文字幕| 99久久亚洲综合精品成人| 久久影视国产亚洲| 五月丁香综合激情六月久久| 国产一级持黄大片99久久| 精品久久综合1区2区3区激情| 欧洲性大片xxxxx久久久| 久久99国产综合精品免费| 国产亚洲美女精品久久久| 人妻无码精品久久亚瑟影视 | 国产精品久久久久久影院 | 91精品国产高清久久久久久io| 99久久国产免费福利| 无码国产69精品久久久久网站| 天天综合久久久网| 久久天天躁狠狠躁夜夜2020一| 久久精品免费观看| 少妇熟女久久综合网色欲| 亚洲国产精品久久久久| 午夜天堂av天堂久久久| 亚洲精品无码久久毛片|