1、 Dump文件放在哪里?
Dump文件不用非要放在你編譯出來的位置,你完全可以建立一個新的文件夾來放它。但若不是存放在編譯出來的位置,需要將編譯生成的PDB文件拷貝到Dump文件目錄,或是利用VS2005打開Dump文件后,設置PDB文件路徑。
2、 如何恢復當時的現場?
可能你要問,怎么可能,這個dump文件可是用戶發給我的,我不可能去用戶家里調試吧?這個恢復現場可不是指的非要到那臺機器上去,而是要把產生dump文件對應的二進制文件拿到。
但是恢復現場需要所有的二進制文件都要對應,你一定要有導致用戶崩潰的那些Exe和DLL。既然是你發布的程序,Exe文件當然你會有。所以這里只考慮DLL就行了。
Dump文件中記錄了所有DLL文件的版本號和時間戳,所以你一定可以同過某種途徑拿到它。如果你能從用戶那里拿到最好,如果不方便,用戶不可能用的是我們平常不常用的操作系統,所以找個有對應系統的機器一般都會有。但是記住不僅是文件名稱要一致,還要核對版本和時間戳,如果不同一樣沒有辦法用。
如果客戶用了某個特殊的補丁怎么辦?
其實這個問題也很好解決,只要它不阻礙閱讀堆棧,就不用管它,調試Dump和運行程序不一樣,缺少一兩個DLL沒有任何問題。
3、 如果真的需要怎么辦?
符號文件現在主要是指PDB文件。
如果沒有符號文件,那么調試的時候可能導致堆棧錯誤。
如果你丟失了這個發布版本中你編譯出來的那些exe和DLL的PDB,那么這個損失是嚴重的,重新編譯出來的版本是不能使用的。
我自己的DLL都有了,可是缺的是系統的DLL的對應PDB文件怎么辦?圖1.4中已經介紹了方法。微軟在它的符號數據庫上為我們提供了所有的PDB文件,還有部分非關鍵DLL。設置好后程序將自動下載需要的PDB及DLL文件。
4、 拿到需要的文件了,這些文件應該放在哪里?
符號數據庫中的文件不用動,把其它的exe和DLL、PDB文件放在dump文件目錄里就行了。
5、 我用的是VS2005,明明有源代碼,為什么顯示不了?
這個是dump調試的最頭痛問題,代碼可能已經改過了,即使你從SVN拿到當時的版本,時間戳也是錯的,VS2005就是不讓你顯示代碼。其實只要在
Tools/Options,Debugging/General中去掉
Require source files to exactly match the original version的復選就行了。