試可以幫助識別和解決應(yīng)用程序缺陷,在本文中,作者將使用大家常用的的開發(fā)工具Eclipse來調(diào)試Java應(yīng)用程序。但這里介紹的調(diào)試方法基本都是通用的,也適用于NetBeans IDE,我們會把重點(diǎn)放在運(yùn)行時上面。
在本文中使用的是Eclipse Juno版(Eclipse 4.2),在開始前給大家提3點(diǎn)建議!
1、不要使用System.out.println作為調(diào)試工具
2、把所有涉及到的組件日志級別激活并使用
3、使用日志分析器來讀取日志
1.條件斷點(diǎn)
如果你不知道如何添加斷點(diǎn),只需點(diǎn)擊左邊面板(行號前面)斷點(diǎn)即被創(chuàng)建。在調(diào)試界面中,“斷點(diǎn)”視圖會把所有被創(chuàng)建的斷點(diǎn)列出來。我們可以給它加一個布爾條件,也就是說,該斷點(diǎn)會被激活并且如果布爾條件為真,就會執(zhí)行該斷點(diǎn),否則將會跳過往下執(zhí)行。
2.異常斷點(diǎn)
在斷點(diǎn)視圖中,有一個J!標(biāo)記按鈕!我們可以使用該按鈕來添加一個Java異常斷點(diǎn)。例如,我們想讓程序在遇到空指針異常(NullPointerException)時,仍然能繼續(xù)調(diào)試,那么我們可以使用該按鈕來添加一個異常斷點(diǎn)!
3.監(jiān)視點(diǎn)
這是一個非常好的功能,當(dāng)選定的屬性訪問或修改程序時,程序會停止執(zhí)行并允許進(jìn)行調(diào)試。在Outline視圖中選擇一個類變量并從上下文菜單中選擇切換監(jiān)視點(diǎn),屬性監(jiān)視點(diǎn)將會被創(chuàng)建,在斷點(diǎn)(Breakpoints)視圖中會把所有監(jiān)視點(diǎn)用列表的形式顯示出來。
4.評估/檢查
按Ctrl+Shift+D或者Ctrl+Shift+I來顯示選定變量或者表達(dá)式的值。我們也可以給一個變量或表達(dá)式添加永久觀察點(diǎn),當(dāng)程序在調(diào)試時,這些觀察點(diǎn)就會在表達(dá)式視圖(Expression view)中顯示出來。
5.修改變量值
在調(diào)試過程中,我們可以修改變量值。先選好一個變量然后進(jìn)入變量視圖(Variables view),根據(jù)變量類型在其對應(yīng)的Value列里輸入值即可。
6.在Main函數(shù)里面停止執(zhí)行
在運(yùn)行/調(diào)試設(shè)置中,編輯配置對話框中有“Main”這個選項(xiàng)卡,我們可以勾選“Stop in main”這個復(fù)選框。如果選中,那么在調(diào)試一個基于main方法的Java程序時,程序會在main方法第一行位置便停止執(zhí)行。
7.環(huán)境變量
并不是在系統(tǒng)屬性中添加環(huán)境變量,我們可以在編輯配置對話框中很方便地進(jìn)行添加。
8.Drop to Frame
這也是我最喜歡的一個功能。調(diào)試期間,可以重新跳到調(diào)用堆??蚣艿拈_始處執(zhí)行,并且變量值也會回到最初。根據(jù)回檔調(diào)整堆棧的深度,這個功能的主要用途是所有變量狀態(tài)可以快速回到方法開始執(zhí)行時候的樣子,然后你可以重新進(jìn)行一遍一遍執(zhí)行,這樣就可以在你關(guān)注的地方進(jìn)行多次調(diào)試,但是在執(zhí)行過程中也會產(chǎn)生一些副作用,比如插入到數(shù)據(jù)庫里面的數(shù)據(jù)是無法刪除的!
9.分布過濾
當(dāng)我們進(jìn)入(F5)方法的時候,我們還可以訪問其外部庫(比如java.*),我們可能不需要這個庫,就可以在Perference選項(xiàng)卡頁面添加一個過濾器來排除這個包。
10.進(jìn)入、跳出和返回
我把這個放在最后一點(diǎn),在調(diào)試過程中,這些是必須要了解(最好掌握)的東西:
F5——進(jìn)入:移動到下一個步驟,如果當(dāng)前行有一個方法調(diào)用,該控件將會跳轉(zhuǎn)到被調(diào)用方法的第一行執(zhí)行。
F6——跳出:移動到下一行。如果在當(dāng)前行有方法調(diào)用,那么會直接移動到下一行執(zhí)行。不會進(jìn)入被調(diào)用方法體里面。
F7——返回:從當(dāng)前方法中跳出,繼續(xù)往下執(zhí)行。
F8——移動到下一個斷點(diǎn)處執(zhí)行。