如何除錯程式的 Release 版本

Mobidogs發表於2020-04-04
很多時候程式的 Debug 版本執行沒有任何問題,但是一旦釋出 Release 版本後,執行就出錯,著實讓人鬱悶。大家知道,VC++ 中 Release 版本是對無法對原始碼進行除錯的。一般的做法是在懷疑有錯誤的程式碼前後插入MessageBox 函式,在函式中顯示可能導致錯誤的變數的值。或者插入寫檔案的語句,輸出可能導致錯誤的變數的值到一個記錄檔案。其實,除了上面講的這個辦法之外,還有其它的途徑來除錯 Release 版本的。下面就結合自己的經驗和網上查詢的一些資料給出除錯 Release 版本的兩個方法:

方法一、利用 *.PDB 符號檔案除錯 Release 版本
在 VCKBASE 的線上雜誌中有一篇參考文章:符號檔案——Windows 應用程式除錯必備(http://www.vckbase.com/document/viewdoc/?id=1710),文章談到了如何產生 Release 版本二進位制檔案對應的 PDB 檔案的問題。有了 PDB 檔案後,就可以除錯 Release 了,方法是:
    1、在Project Settings裡選Settings For為All Configurations。
    2、在C/C++標籤中,Debug info 選 Program Database。
    3、在Link 標籤中,Category選 Debug,選中Debug info 核取方塊和Microsoft format。
進行了上述設定後,我們就可以像在除錯版本中那樣設定斷點進行測試了,由於程式碼優化,有些變數觀察不到,行的執行順序可能也會不同。
有一點需要注意:ASSERT巨集在 Release 版本中不起作用,在 Release 版本中應該使用 VERIFY 來代替 ASSERT 進行除錯。如果發行版本執行有問題,可以先禁止所有程式碼優化再進行除錯。

方法二、在需要加斷點的地方新增如下彙編語句:
    __asm int 3

不過除錯的時候無法顯示C程式,只有asm程式碼。
    
此處 int 3 是專門用來設定斷點的,是 CPU 定義的,Windows 和 DOS 下的大多數偵錯程式都採用這種方法。

本貼不斷更新中,希望大家跟貼貢獻出更好的除錯方法。以便受益者少走彎路......
 

相關文章