1. 程式人生 > >VS2012之除錯技巧

VS2012之除錯技巧

除錯是軟體開發週期中很重要的一部分。它具有挑戰性,同時也很讓人疑惑和煩惱。總的來說,對於稍大一點的程式,除錯是不可避免的。最近幾年,除錯工具的發展讓很多除錯任務變的越來越簡單和省時。

這篇文章總結了可能節省你大量時間的11個Visual studio的除錯技巧和方法。

1 懸停滑鼠查看錶達式值

除錯是很有挑戰性的。比如在函式內逐步執行可以看出哪裡出錯,檢視堆疊資訊可以知道函式被誰呼叫等等……但是無論哪種情況下,查看錶達式和區域性變數 的值都是很麻煩的(把表示式和區域性變數放到watch窗口裡)。一種更簡單的方法,把滑鼠停在所需檢視的資料上。如果是類或結構,那麼點選展開可以很方便 快速地檢視其欄位。

2 在執行過程中改變變數值

偵錯程式不僅僅是分析程式崩潰和詭異行為的工具,還可以通過逐步除錯檢查資料和行為是否符合程式預期的方法解決許多bug。有時,你會想是否設定某些 條件為真,程式就能正確運行了。其實你只要把滑鼠移動到變數上,雙擊值,然後輸入你需要的值。這樣就不需要修改程式碼,重啟程式了。

3 設定下一個執行位置

一個典型的除錯案例是我們經常會用逐步除錯的方法去分析為什麼函數出錯了。這時你遇到這個函式呼叫其他函式返回錯誤,而這個錯誤不是你想要的,你該 怎麼辦?重啟偵錯程式?這裡有個更好的方法,直接把黃色的執行位置箭頭拖到你想要的執行位置。其實就是跳過中間執行程式碼,直接到想要的位置。很簡單吧。

4 編輯然後繼續執行

在執行一個很複雜的程式和外掛時,發現一個錯誤,但是不想浪費時間去重編譯重啟動程式。很簡單,只要在這個位置修改這個bug,然後繼續除錯。Visual studio會修改這個程式,使得你可以繼續除錯而不需要重啟程式。

值得注意的是“編輯然後繼續執行”這個功能有幾個限制。一,它不能在64位程式碼上使用。如果想使用這個功能,到專案設定裡的編譯選項,選 擇”x86”作為目標平臺。不要擔心,這目標平臺在reslease配置是和”debug是分離的,也就是說依然是”Any CPU”的設定。二,“編輯然後繼續執行”這個功能僅適用於一個函式內部改變。如果你想要改變這個函式的宣告或者增加新的方法,你只能選擇重啟程式,或者 不做任何改變繼續。如果修改的方法中包含lambda表示式,則意味著修改了編譯器自動生成的委託型別,這樣會導致編譯器停止執行。

5 一個方便的檢視視窗

大部分現代的偵錯程式都有檢視視窗。但是,visual studio的檢視視窗使用特別簡單,你能很方便的增加和刪除變數。只要在窗口裡點選空白行,輸入表示式然後按enter鍵。或者點選表示式,按delete鍵刪除不需要的表示式。

在除錯視窗不僅僅可以檢視普通的變數值,甚至可以輸入$handles去追蹤開啟的控制代碼數量,$err去檢視函式的錯誤程式碼(然後使用 Tools->Error 檢視錯誤程式碼的描述)或者輸入 @eax(在64位下是@rax )檢視包含函式返回值的暫存器值。

6 註釋反彙編

使用內部的反彙編功能使得優化區域性程式碼更加簡單。Visual studio可以在你的每一行程式碼下顯示彙編指令,並且可以逐步除錯彙編程式碼,也可以在任意位置設定斷點。檢視和修改彙編程式碼類似於c++。

7 堆疊資訊的執行緒視窗

除錯多執行緒程式碼是很痛苦的。或許也是有趣的。這取決於你的偵錯程式。Visual studio 一個很讚的功能就是線上程視窗檢視執行緒的堆疊資訊。你能很方便的直接看到所有執行緒以及他們的堆疊資訊。

8 條件斷點

如果你想重現一個小概率事件,但是斷點在大量不需要的條件下也會觸發。你可以很簡單的設定條件斷點。在斷點視窗設定該斷點條件,Visual studio 會自動忽略不符合條件的斷點。

9 記憶體視窗

一些bug是由錯誤的結構定義、缺少對齊屬性等原因引起的。檢視每行記憶體的內容很容易定位和解決這些bug. Visual studio 的記憶體視窗可以把資料翻譯成8/16/32/64-bit數字或者浮點數。你可以在編輯視窗直接改變數值。

10 跳轉到定義

如果你在解決別人寫的程式碼一個bug,會遇到“這個型別是什麼”“這個函式做什麼的”之類的問題,你可以使用visual studio的跳轉到定義的命令來檢視型別或函式的定義。

11 命令視窗

這個小技巧是由chaau建議的,它能節省你大量的時間。Visual studio支援一個命令視窗,你可以通過選單View->Other Windows->Command Window 開啟。你可以在窗口裡輸入不同命令使除錯自動化。比如,可以通過很簡單的命令去的測試MFC的COleDateTime變數。