IDEA的5大調(diào)試技巧,你學(xué)廢了嗎?
點(diǎn)擊關(guān)注公眾號(hào),Java干貨及時(shí)送達(dá)
來(lái)源微信公眾號(hào):JAVA日知錄
在項(xiàng)目開(kāi)發(fā)的時(shí)候我發(fā)現(xiàn)很多小伙伴能非常熟練的使用IDEA編寫代碼,但是對(duì)于IDEA調(diào)試的技巧掌握的不是很好,只會(huì)F7、F8、F9等這些基本調(diào)試功能。 而像一些復(fù)雜的調(diào)試場(chǎng)景就無(wú)從下手,如:在 for循環(huán)中調(diào)試某個(gè)特定值;多線程、Reactor調(diào)試;修改變量的運(yùn)行值等。下面我們就來(lái)分場(chǎng)景介紹一下IDEA的調(diào)試技巧,看完掌握后調(diào)試bug的效率一定大大提升。 1. 條件斷點(diǎn)
循環(huán)中經(jīng)常用到這個(gè)技巧,比如:遍歷1個(gè)大List的過(guò)程中,想讓斷點(diǎn)停在某個(gè)特定值。 參考上圖,在斷點(diǎn)的位置,右擊斷點(diǎn)旁邊的小紅點(diǎn),會(huì)出來(lái)一個(gè)界面,在Condition這里填入斷點(diǎn)條件即可,這樣調(diào)試時(shí),就會(huì)自動(dòng)停在i=10的位置。 2. 回到"上一步"
該技巧最適合特別復(fù)雜的方法套方法的場(chǎng)景,好不容易跑起來(lái),一不小心手一抖,斷點(diǎn)過(guò)去了,想回過(guò)頭看看剛才的變量值,如果不知道該技巧,只能再跑一遍。 參考上圖,method1方法調(diào)用method2,當(dāng)前斷點(diǎn)的位置j=100,點(diǎn)擊上圖紅色箭頭位置的Drop Frame圖標(biāo)后,時(shí)間穿越了 回到了method1剛開(kāi)始調(diào)用的時(shí)候,變量i變成了99,沒(méi)毛病吧,老鐵們,是不是很6 :) 注:好奇心是人類進(jìn)步的階梯,如果想知道為啥這個(gè)功能叫Drop Frame,而不是類似Back To Previous 之類的,可以去翻翻JVM的書,JVM內(nèi)部以棧幀為單位保存線程的運(yùn)行狀態(tài),drop frame即扔掉當(dāng)前運(yùn)行的棧幀,這樣當(dāng)前“指針”的位置,就自然到了上一幀的位置。 3.多線程調(diào)試
多線程同時(shí)運(yùn)行時(shí),誰(shuí)先執(zhí)行,誰(shuí)后執(zhí)行,完全是看CPU心情的,無(wú)法控制先后,運(yùn)行時(shí)可能沒(méi)什么問(wèn)題,但是調(diào)試時(shí)就比較麻煩了,最明顯的就是斷點(diǎn)亂跳,一會(huì)兒停這個(gè)線程,一會(huì)兒停在另一個(gè)線程,比如下圖: 如果想希望下一個(gè)斷點(diǎn)位置是第2句詩(shī)句,可能要失望了: 如果想讓線程在調(diào)試時(shí),想按自己的愿意來(lái),讓它停在哪個(gè)線程就停在哪個(gè)線程,可以在圖中3個(gè)斷點(diǎn)的小紅點(diǎn)上右擊, 即:Suspend掛起的條件是按每個(gè)線程來(lái),而非All。把這3個(gè)斷點(diǎn)都這么設(shè)置后,再來(lái)一發(fā)試試 注意上圖中的紅框位置,斷點(diǎn)停下來(lái)時(shí),這個(gè)下拉框可以看到各個(gè)線程(注:給線程起個(gè)容易識(shí)別的名字是個(gè)好習(xí)慣!),我們可以選擇線程“天空中的飛鳥(niǎo)” 斷點(diǎn)如愿停在了第2句詩(shī)。 4.遠(yuǎn)程調(diào)試
這也是一個(gè)裝B的利器,本機(jī)不用啟動(dòng)項(xiàng)目,只要有源代碼,可以在本機(jī)直接遠(yuǎn)程調(diào)試服務(wù)器上的代碼,打開(kāi)姿勢(shì)如下: 4.1 項(xiàng)目啟動(dòng)時(shí),先允許遠(yuǎn)程調(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 注意:遠(yuǎn)程調(diào)試從技術(shù)上講,就是在本機(jī)與遠(yuǎn)程建立scoket通訊,所以端口不要沖突,而且本機(jī)要允許訪問(wèn)遠(yuǎn)程端口,另外這一段參數(shù),放要在-jar 或 ${main_class}的前面 4.2 idea中設(shè)置遠(yuǎn)程調(diào)試
然后就可以調(diào)試了
前提是本機(jī)有項(xiàng)目的源代碼 ,在需要的地方打個(gè)斷點(diǎn),然后訪問(wèn)一個(gè)遠(yuǎn)程的url試試,斷點(diǎn)就會(huì)停下來(lái)。 5. 臨時(shí)執(zhí)行表達(dá)式/修改變量的運(yùn)行值
調(diào)試時(shí),可以臨時(shí)執(zhí)行一些表達(dá)式,參考下圖:點(diǎn)擊這二個(gè)圖標(biāo)中的任何1個(gè)都可以
點(diǎn)擊+號(hào)后,就可以在新出現(xiàn)的輸入框里輸入表達(dá)式,比如i+5
然后回車,馬上就能看到結(jié)果
當(dāng)然,如果調(diào)試時(shí),想動(dòng)態(tài)修改變量的值,也很容易,在變量上右擊,然后選擇Set Value,剩下的事,地球人都知道。 好了,今天的文章就到這里了,牢記這5大調(diào)試技巧可以讓你快速定位問(wèn)題,迅速解決bug,最后祝大家debug愉快! (完) 加我"微信" 獲取一份 最新Java面試題資料 請(qǐng)備注:666,不然不通過(guò)~
最近好文
1、Spring Boot 實(shí)現(xiàn)掃碼登錄,這種方式太香了??!
2、SpringSecurity + JWT 實(shí)現(xiàn)單點(diǎn)登錄
3、基于 Vue+Spring 前后端分離管理系統(tǒng)ELAdmin
最近面試BAT,整理一份面試資料《Java面試BAT通關(guān)手冊(cè)》,覆蓋了Java核心技術(shù)、JVM、Java并發(fā)、SSM、微服務(wù)、數(shù)據(jù)庫(kù)、數(shù)據(jù)結(jié)構(gòu)等等。 獲取方式:關(guān)注公眾號(hào)并回復(fù) java 領(lǐng)取,更多內(nèi)容陸續(xù)奉上。 明天見(jiàn)(??ω??)??
評(píng)論
圖片
表情
















