可以幫助辨識和解決應用程式缺陷,在本文中,作者將使用大家常用的開發工具Eclipse來偵錯Java應用程式。但這裡介紹的調試方法基本上都是通用的,也適用於NetBeans IDE,我們會把重點放在執行時上面。
在開始之前,推薦大家去看看Eclipse shortcuts這篇文章,它將會為你帶來很多方便。本文使用的是Eclipse Juno版(Eclipse 4.2),開始前先給大家3點建議!
不要使用System.out.println作為調試工具把所有涉及的組件日誌等級啟動並使用使用日誌分析器來讀取日誌
1.條件斷點
如果你不知道如何加入斷點,只需點擊左邊面板(行號前面)斷點即被建立。在偵錯介面中,「斷點」視圖會把所有被建立的斷點列出來。我們可以給它加一個布林條件,也就是說,該斷點會被啟動並且如果布林條件為真,就會執行該斷點,否則將會跳過往下執行。
2.異常斷點
在斷點視圖中,有一個J!標記按鈕!我們可以使用該按鈕來新增一個Java異常斷點。例如,我們想讓程式在遇到空指標異常(NullPointerException)時,仍然能繼續除錯,那麼我們可以使用該按鈕來新增一個異常斷點!
3.監視點
這是一個非常好的功能,當選定的屬性存取或修改程式時,程式會停止執行並允許進行偵錯。在Outline視圖中選擇一個類別變數並從上下文選單中選擇切換監視點,屬性監視點將會被創建,在斷點(Breakpoints)視圖中會把所有監視點用列表的形式顯示出來。
4.評估/檢查
按Ctrl+Shift+D或Ctrl+Shift+I來顯示選取變數或表達式的值。我們也可以為一個變數或表達式新增永久觀察點,當程式在偵錯時,這些觀察點就會在表達式視圖(Expression view)中顯示出來。
5.修改變數值
在調試過程中,我們可以修改變數值。先選好一個變數然後進入變數視圖(Variables view),根據變數型別在對應的Value欄位裡輸入值即可。
6.在Main函數裡面停止執行
在運行/調試設定中,編輯配置對話框中有“Main”這個選項卡,我們可以勾選“Stop in main”這個複選框。如果選中,那麼在偵錯一個基於main方法的Java程式時,程式會在main方法第一行位置便停止執行。
7.環境變數
並不是在系統屬性中加入環境變量,我們可以在編輯配置對話框中很方便地進行新增。
8.Drop to Frame
這也是我最喜歡的功能。在偵錯期間,可以重新跳到呼叫堆疊框架的開始處執行,變數值也會回到最初。根據回檔調整堆疊的深度,這個功能的主要用途是所有變數狀態可以快速回到方法開始執行時候的樣子,然後你可以重新進行一遍又一遍執行,這樣就可以在你關注的地方進行多次調試,但在執行過程中也會產生一些副作用,例如插入到資料庫裡面的資料是無法刪除的!
9.分佈過濾
當我們進入(F5)方法的時候,我們還可以存取其外部庫(例如java.*),我們可能不需要這個庫,就可以在Perference選項卡頁面添加一個過濾器來排除這個套件。
10.進入、跳出和返回
我把這個放在最後一點,在調試過程中,這些是必須要了解(最好掌握)的東西:
F5――進入:移動到下一個步驟,如果目前行有一個方法調用,該控制項將會跳到被調用方法的第一行執行。
F6――跳出:移動到下一行。如果在當前行有方法調用,那麼會直接移動到下一行執行。不會進入被呼叫方法體裡面。
F7――返回:從目前方法中跳出,繼續往下執行。
F8――移動到下一個斷點處執行。