|
本文寫(xiě)給那些像幾年前的我一樣剛剛走出校門(mén),及一些未使用過(guò)這些高級(jí)些的調(diào)試技巧的人。
記得剛剛畢業(yè)的時(shí)候,自己連斷點(diǎn)也不會(huì)打,當(dāng)時(shí)還在用JCreate ,就連畢業(yè)設(shè)計(jì)也是用 System.out 找 Bug 的,想想真的很笨。開(kāi)始工作后,一個(gè)星期過(guò)去了,在一個(gè) 1 、 2 百萬(wàn)行的系統(tǒng)中找 Bug ,我依然在用 System.out ,當(dāng)時(shí)最痛苦的就是修改代碼,每次找到疑似 Bug ,就輸出一下,然后重啟(那時(shí)也不知道代碼熱替換),直到有一天帶我的導(dǎo)師發(fā)現(xiàn)了這樣笨笨的調(diào)試 Bug ,才讓我第一次認(rèn)識(shí)了斷點(diǎn),也知道了代碼修改完了可以進(jìn)行熱替換,我這個(gè)中國(guó)教育的半犧牲品才算向美好生活邁進(jìn)了一小步。
1、 條件斷點(diǎn)
斷點(diǎn)大家都比較熟悉,在EclipseJava 編輯區(qū)的行頭雙擊就會(huì)得到一個(gè)斷點(diǎn),代碼會(huì)運(yùn)行到此處時(shí)停止。
條件斷點(diǎn),顧名思義就是一個(gè)有一定條件的斷點(diǎn),只有滿(mǎn)足了用戶(hù)設(shè)置的條件,代碼才會(huì)在運(yùn)行到斷點(diǎn)處時(shí)停止。
在斷點(diǎn)處點(diǎn)擊鼠標(biāo)右鍵,選擇最后一個(gè)"BreakpointProperties"
斷點(diǎn)的屬性界面及各個(gè)選項(xiàng)的意思如下圖,
2、 變量斷點(diǎn)
斷點(diǎn)不僅能打在語(yǔ)句上,變量也可以接受斷點(diǎn),
上圖就是一個(gè)變量的打的斷點(diǎn),在變量的值初始化,或是變量值改變時(shí)可以停止,當(dāng)然變量斷點(diǎn)上也是可以加條件的,和上面的介紹的條件斷點(diǎn)的設(shè)置是一樣的。
3、 方法斷點(diǎn)
方法斷點(diǎn)就是將斷點(diǎn)打在方法的入口處,
方法斷點(diǎn)的特別之處在于它可以打在 JDK的源碼里,由于 JDK 在編譯時(shí)去掉了調(diào)試信息,所以普通斷點(diǎn)是不能打到里面的,但是方法斷點(diǎn)卻可以,可以通過(guò)這種方法查看方法的調(diào)用棧。
4、 改變變量值
代碼停在了斷點(diǎn)處,但是傳過(guò)來(lái)的值不正確,如何修改一下變量值保證代碼繼續(xù)走正確的流程,或是說(shuō)有一個(gè)異常分支老是進(jìn)不去,能不能調(diào)試時(shí)改一下條件,看一下異常分支代碼是否正確?
在Debug 視圖的 Variables 小窗口中,我們可以看到 mDestJarName 變量的值為 " F:/Study/eclipsepro/JarDir/jarHelp.jar "
我們可以在變量上右鍵,選擇"ChangeValue..." 在彈出的對(duì)話(huà)框中修改變量的值,
或是在下面的值查看窗口中修改,保用Ctr+S 保存后,變量值就會(huì)變成修改后的新值了。
5、 重新調(diào)試
這種調(diào)試的回退不是萬(wàn)能的,只能在當(dāng)前線(xiàn)程的棧幀中回退,也就說(shuō)最多只能退回到當(dāng)前線(xiàn)程的調(diào)用的開(kāi)始處。
回退時(shí),請(qǐng)?jiān)谛枰赝说木€(xiàn)程方法上點(diǎn)右鍵,選擇 "DroptoFrame"
6、 遠(yuǎn)程調(diào)試
用于調(diào)試不在本機(jī)上的程序,有兩種方式,
1、本機(jī)作為客戶(hù)端
2、本機(jī)作為服務(wù)端
使用遠(yuǎn)程調(diào)試的前提是服務(wù)器端和客戶(hù)端的代碼是一致的。
本機(jī)作為客戶(hù)端
本機(jī)作客戶(hù)端比較常用,需要在遠(yuǎn)端的服務(wù)器上的Java程序在啟動(dòng)時(shí)打開(kāi)遠(yuǎn)程調(diào)試開(kāi)關(guān),
服務(wù)器端需要加上虛擬機(jī)參數(shù)
1.5以前版本(1.5以后也可用):【-Xdebug -Xrunjdwp:transport=dt_socket,server=y,address=8000 】
1.5及以上版本:【 -agentlib:jdwp=transport=dt_socket,server=y,address=8000】
F:/Study/eclipsepro/screensnapJava -Xdebug -Xrunjdwp:transport=dt_socket,server=y,address=8000 -jar screensnap3.jar
連接時(shí)遠(yuǎn)程服務(wù)器時(shí),需要在Eclipse中新建一個(gè)遠(yuǎn)程調(diào)試程序
這里有一個(gè)小地方需注意,連接上的時(shí)候貌似不能自動(dòng)切換到Debug視圖,不要以為本機(jī)的調(diào)試程序沒(méi)有連接到服務(wù)器端。
本機(jī)作為服務(wù)端
同本機(jī)作為客戶(hù)端相比,只需要修改一下Connection Type
這時(shí)Eclipse會(huì)進(jìn)入到等待連接的狀態(tài)
連接程序使用如下參數(shù)即可連接本機(jī)服務(wù)器,IP地址請(qǐng)用實(shí)現(xiàn)IP替換~~
【-agentlib:jdwp=transport=dt_socket,suspend=y,address=127.0.0.1:8000】
F:/Study/eclipsepro/screensnapJava -agentlib:jdwp=transport=dt_socket,suspend=y,address=127.0.0.1:8000 -jar screensnap3.jar
遠(yuǎn)程調(diào)試時(shí)本地的代碼修改可同步到遠(yuǎn)程,但不會(huì)寫(xiě)到遠(yuǎn)程的文件里,也就是說(shuō)本地修改會(huì)在下次啟動(dòng)遠(yuǎn)程程序時(shí)就沒(méi)有了,不會(huì)影響到下次使用時(shí)的遠(yuǎn)程代碼。
7、異常斷點(diǎn)
經(jīng)常遇見(jiàn)一些異常,然后程序就退出來(lái)了,要找到異常發(fā)生的地方就比較難了,還好可以打一個(gè)異常斷點(diǎn),
上圖中我們?cè)黾恿艘粋€(gè)NullPointException的異常斷點(diǎn),當(dāng)異常發(fā)生時(shí),代碼會(huì)停在異常發(fā)生處,定位問(wèn)題時(shí)應(yīng)該比較有幫助。
it知識(shí)庫(kù):Eclipse調(diào)試Bug的七種常用技巧,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。