• <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>

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            利用VS2005進行dump文件調試

            前言:利用drwtsn32NTSD進行程序崩潰處理,都可以生成可用于調試的dmp格式文件。使用VS2005打開生成的DMP文件,能很方便的找出BUG所在位置。本文將討論以下內容:

            1  程序編譯選項

            2  利用VS2005 分析dump文件

            3  常見問題討論

            一、       程序編譯選項

            PDB files contains all debug information like type definition and function prototype. When application crashes, we need the PDB files to analyze the root cause, so make sure these PDB files will be created when building it. You must do the following setting:

            C/C++\General\Debug Information Format=Program Database (/Zi).

            clip_image001

            1.1 調試信息格式

            Linker\Debugging\Generate Program Database File=”Name and location of your PDB files”

            clip_image002

            1.2 PDB文件輸出路徑

            PDB文件路徑最好設置在同一個文件夾中,這樣方便dmp文件調試時調用。

            調試時,所有的PDB文件和源文件必須嚴格匹配(the PDB files should be the one generated by build the source code),并存儲在一個安全的位置。當客戶報告了一個錯誤時,你需要這些文件來幫忙以便定位錯誤于源代碼中并解決問題。

            二、       VS2005 分析dump文件

            In this simple application, there is an unhandled Access Violation Reading exception, because GetNameFromDatabase returns a NULL pointer, and this pointer is passed into IsPrefix and then it’s used directly without NULL pointer checking.

            clip_image003

            1.3 演示代碼

             

            利用Release模式編譯該測試程序,在客戶機上運行該程序,將根據NTSD設置生成相對應的DMP格式文件。

            可以使用Visual Studio.NetNTSD或是其他的調試工具對DMP格式文件進行分析。

             

            l         Start Visual Studio.Net

            Click File\Open Solution and make sure the files of type is *.dmp then click Open.

            clip_image004

            1.3 Open Dump File (GUI)

             

            l         Set Symbol Path

            Click Tools\Options, Debugging\Symbols,增加PDB文件路徑。若調試的程序需要微軟基礎庫的PDB信息,可以增加一個路徑為:

            http://msdl.microsoft.com/download/symbols

            在界面下方Cache Symbol From symbol…選擇本地存儲這些Symbols的路徑。

            clip_image005

            1.4 Symbol Path

            如果DMP文件沒有放入本身PDB文件所在目錄,也可以在此處增加一個本地目錄。點OK后,VS2005將從網絡中下載所需要的Symbols,需要等待一段時間。如果是多次調試同一個程序錯誤所生成的DMP文件,可以在對話框中選擇“Search the above locations only when symbols are loaded manually”。從而可以節省網絡帶寬。

             

            l         Set Source code path

            Open Solution Property Pages and set the source code path.

            clip_image006

            1.5 屬性菜單

            clip_image007

            1.6 Debug Source Files

             

            l         Start to Debug the Dump File

            Click the Debug menu, it will ask you to save as a solution, save it. Then it will go to the line which caused the crash of your application.

            clip_image008

            1.7 調試窗口,定位到源代碼

             

            三、       常見問題討論

            1  Dump文件放在哪里?

            Dump文件不用非要放在你編譯出來的位置,你完全可以建立一個新的文件夾來放它。但若不是存放在編譯出來的位置,需要將編譯生成的PDB文件拷貝到Dump文件目錄,或是利用VS2005打開Dump文件后,設置PDB文件路徑。參照圖1.4

             

            2  如何恢復當時的現場?

            可能你要問,怎么可能,這個dump文件可是用戶發給我的,我不可能去用戶家里調試吧?這個恢復現場可不是指的非要到那臺機器上去,而是要把產生dump文件對應的二進制文件拿到。

            但是恢復現場需要所有的二進制文件都要對應,你一定要有導致用戶崩潰的那些ExeDLL。既然是你發布的程序,Exe文件當然你會有。所以這里只考慮DLL就行了。

            Dump文件中記錄了所有DLL文件的版本號和時間戳,所以你一定可以同過某種途徑拿到它。如果你能從用戶那里拿到最好,如果不方便,用戶不可能用的是我們平常不常用的操作系統,所以找個有對應系統的機器一般都會有。但是記住不僅是文件名稱要一致,還要核對版本和時間戳,如果不同一樣沒有辦法用。

            如果客戶用了某個特殊的補丁怎么辦?

            其實這個問題也很好解決,只要它不阻礙閱讀堆棧,就不用管它,調試Dump和運行程序不一樣,缺少一兩個DLL沒有任何問題。

             

            3  如果真的需要怎么辦?

            符號文件現在主要是指PDB文件。

            如果沒有符號文件,那么調試的時候可能導致堆棧錯誤。

            如果你丟失了這個發布版本中你編譯出來的那些exeDLLPDB,那么這個損失是嚴重的,重新編譯出來的版本是不能使用的。

            我自己的DLL都有了,可是缺的是系統的DLL的對應PDB文件怎么辦?圖1.4中已經介紹了方法。微軟在它的符號數據庫上為我們提供了所有的PDB文件,還有部分非關鍵DLL。設置好后程序將自動下載需要的PDBDLL文件。

             

            4  拿到需要的文件了,這些文件應該放在哪里?

            符號數據庫中的文件不用動,把其它的exeDLLPDB文件放在dump文件目錄里就行了。

             

            5  我用的是VS2005,明明有源代碼,為什么顯示不了?

            這個是dump調試的最頭痛問題,代碼可能已經改過了,即使你從SVN拿到當時的版本,時間戳也是錯的,VS2005就是不讓你顯示代碼。其實只要在

            Tools\OptionsDebugging\General中去掉

            Require source files to exactly match the original version的復選就行了。

             

            posted on 2009-10-21 18:58 肥仔 閱讀(20783) 評論(3)  編輯 收藏 引用 所屬分類: 調試

            評論

            # re: 利用VS2005進行dump文件調試  回復  更多評論   

            寫得很不錯,剛想學習這方面的知識。謝謝啦。
            2011-09-11 15:06 | xin

            # re: 利用VS2005進行dump文件調試[未登錄]  回復  更多評論   

            好像dll中出問題時,出錯的地方和找的位置不總是能對上號
            2012-08-03 09:17 | 花花

            # re: 利用VS2005進行dump文件調試  回復  更多評論   

            不錯,工具是什么、怎么用清楚了,程序調試、查錯非常有用
            2017-03-14 23:52 | 黃華仔
            久久久久亚洲AV成人网人人网站| 亚洲精品国产美女久久久| 久久免费视频网站| 久久久精品久久久久特色影视| 人人狠狠综合久久亚洲高清| 久久中文字幕人妻丝袜| 久久亚洲日韩精品一区二区三区| 99久久无色码中文字幕| 久久久国产精品| 久久人爽人人爽人人片AV | 2020国产成人久久精品| 亚洲成色WWW久久网站| 韩国三级大全久久网站| 精品久久久一二三区| 国产精品亚洲美女久久久| 伊人久久精品无码二区麻豆| 亚洲综合精品香蕉久久网97| 国色天香久久久久久久小说| 久久国产视屏| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 国产亚洲综合久久系列| 久久综合视频网站| 精品久久国产一区二区三区香蕉| 久久综合给合久久狠狠狠97色 | 日产精品99久久久久久| 亚洲午夜无码久久久久小说| 久久久精品午夜免费不卡| 无码人妻少妇久久中文字幕蜜桃| 欧美精品丝袜久久久中文字幕| 亚洲国产精品一区二区久久| 久久精品中文字幕无码绿巨人| 午夜精品久久久久| 香蕉久久夜色精品国产2020| 国产福利电影一区二区三区久久老子无码午夜伦不 | 午夜欧美精品久久久久久久 | 99久久精品费精品国产一区二区| 色综合久久无码中文字幕| 久久婷婷国产剧情内射白浆| 91麻豆国产精品91久久久| 久久综合鬼色88久久精品综合自在自线噜噜| 99久久精品国产毛片|