在項目開發(fā)的時候我發(fā)現(xiàn)很多小伙伴能非常熟練的使用IDEA編寫代碼,但是對于IDEA調(diào)試的技巧掌握的不是很好,只會F7、F8、F9等這些基本調(diào)試功能。
而像一些復(fù)雜的調(diào)試場景就無從下手,如:在for循環(huán)中調(diào)試某個特定值;多線程、Reactor調(diào)試;修改變量的運行值等。下面我們就來分場景介紹一下IDEA的調(diào)試技巧,看完掌握后調(diào)試bug的效率一定大大提升。1. 條件斷點
循環(huán)中經(jīng)常用到這個技巧,比如:遍歷1個大List的過程中,想讓斷點停在某個特定值。
條件斷點參考上圖,在斷點的位置,右擊斷點旁邊的小紅點,會出來一個界面,在Condition這里填入斷點條件即可,這樣調(diào)試時,就會自動停在i=10的位置。
條件斷點調(diào)試2. 回到"上一步"
該技巧最適合特別復(fù)雜的方法套方法的場景,好不容易跑起來,一不小心手一抖,斷點過去了,想回過頭看看剛才的變量值,如果不知道該技巧,只能再跑一遍。參考上圖,method1方法調(diào)用method2,當前斷點的位置j=100,點擊上圖紅色箭頭位置的Drop Frame圖標后,時間穿越了
退回上一步回到了method1剛開始調(diào)用的時候,變量i變成了99,沒毛病吧,老鐵們,是不是很6 :)注:好奇心是人類進步的階梯,如果想知道為啥這個功能叫Drop Frame,而不是類似Back To Previous 之類的,可以去翻翻JVM的書,JVM內(nèi)部以棧幀為單位保存線程的運行狀態(tài),drop frame即扔掉當前運行的棧幀,這樣當前“指針”的位置,就自然到了上一幀的位置。3.多線程調(diào)試
多線程同時運行時,誰先執(zhí)行,誰后執(zhí)行,完全是看CPU心情的,無法控制先后,運行時可能沒什么問題,但是調(diào)試時就比較麻煩了,最明顯的就是斷點亂跳,一會兒停這個線程,一會兒停在另一個線程,比如下圖:如果想希望下一個斷點位置是第2句詩句,可能要失望了:如果想讓線程在調(diào)試時,想按自己的愿意來,讓它停在哪個線程就停在哪個線程,可以在圖中3個斷點的小紅點上右擊,即:Suspend掛起的條件是按每個線程來,而非All。把這3個斷點都這么設(shè)置后,再來一發(fā)試試注意上圖中的紅框位置,斷點停下來時,這個下拉框可以看到各個線程(注:給線程起個容易識別的名字是個好習慣!),我們可以選擇線程“天空中的飛鳥”4.遠程調(diào)試
這也是一個裝B的利器,本機不用啟動項目,只要有源代碼,可以在本機直接遠程調(diào)試服務(wù)器上的代碼,打開姿勢如下:4.1 項目啟動時,先允許遠程調(diào)試
java -server -Xms512m -Xmx512m -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=9081 -Djava.ext.dirs=. ${main_class}
-Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=9081
注意:遠程調(diào)試從技術(shù)上講,就是在本機與遠程建立scoket通訊,所以端口不要沖突,而且本機要允許訪問遠程端口,另外這一段參數(shù),放要在-jar 或 ${main_class}的前面4.2 idea中設(shè)置遠程調(diào)試

前提是本機有項目的源代碼 ,在需要的地方打個斷點,然后訪問一個遠程的url試試,斷點就會停下來。5. 臨時執(zhí)行表達式/修改變量的運行值
調(diào)試時,可以臨時執(zhí)行一些表達式,參考下圖:點擊這二個圖標中的任何1個都可以
點擊+號后,就可以在新出現(xiàn)的輸入框里輸入表達式,比如i+5

當然,如果調(diào)試時,想動態(tài)修改變量的值,也很容易,在變量上右擊,然后選擇Set Value,剩下的事,地球人都知道。好了,今天的文章就到這里了,牢記這5大調(diào)試技巧可以讓你快速定位問題,迅速解決bug,最后祝大家debug愉快!
入我相思門,知我相思苦,長相思兮長相憶,短相思兮無窮極。