Intellij IDEA的一些調(diào)試技巧(小結(jié))
程序員的工作內(nèi)容,除了大部分時(shí)間寫(xiě)代碼之外,因?yàn)橛胁簧俚臅r(shí)間是用在調(diào)試代碼上。甚至說(shuō)不是在調(diào)試代碼,就是即將調(diào)試代碼。 :)
今天我們來(lái)談?wù)務(wù){(diào)試代碼的一些技巧,在使用IDE提供的debugger時(shí)一些快速定位問(wèn)題的方式。
看到這里的朋友,不要馬上認(rèn)為我標(biāo)題黨,再往下看看,如果你還有一些更好用的技巧,歡迎留言。
下面進(jìn)入正題。
1 多線程調(diào)試
開(kāi)發(fā)過(guò)多線程應(yīng)用的朋友應(yīng)該有體會(huì),有些時(shí)候,為了觀察多個(gè)線程間變量的不同狀態(tài),以及鎖的獲取等,就會(huì)想到在代碼里加個(gè)斷點(diǎn)debug一下。
在IDE里斷點(diǎn)停下來(lái)的時(shí)候,可以切換到另外的線程中,跑其他的代碼,不會(huì)互相影響。當(dāng)然,這里是有個(gè)開(kāi)關(guān)的,在Eclipse里默認(rèn)開(kāi)啟,
但是在IntelliJ IDEA里默認(rèn)是沒(méi)有開(kāi)啟的。也就是說(shuō)如果你在IDEA里代碼里加斷點(diǎn),雖然一個(gè)線程的斷了下來(lái),但其他線程的已經(jīng)執(zhí)行過(guò)了。
此處把線程的suspend設(shè)置成和Eclipse模式一樣之后,也可以開(kāi)始多線程應(yīng)用的調(diào)試。
簡(jiǎn)單設(shè)置可以直接在斷點(diǎn)處,將suspend改成Thread
更改IDEA中的默認(rèn)設(shè)置:切換到"Thread" Radio Button,點(diǎn)擊出現(xiàn)的按鈕 ”Make Default"
一個(gè)線程斷下來(lái)之后,可以通過(guò)在線程窗口切換,到其它線程中繼續(xù)運(yùn)行。
IntelliJ IDEA里在這兒切換
我們看到main線程和pool-1-thread-1這兩個(gè)線程都處于RUNNING狀態(tài),切換到任何一個(gè)都可以繼續(xù)運(yùn)行。
此時(shí),就可以寫(xiě)一個(gè)多線程的應(yīng)用,同時(shí)向ArryList這一類(lèi)非線程安全的容器中存放內(nèi)容,然后觀察為什么他們是線程不安全的,會(huì)出現(xiàn)什么問(wèn)題,生動(dòng)又形象。
PS: 這里順道說(shuō)一下,這就是為什么創(chuàng)建線程時(shí)建議起一個(gè)有意義的名字 ,至少是可以識(shí)別的名字,否則在這里都不能區(qū)分出哪個(gè)是自己的線程,想切換還麻煩。
2 后退執(zhí)行
這里所說(shuō)的后退執(zhí)行,是有些時(shí)候我們?cè)赿ebug代碼時(shí),懶的每個(gè)方法都進(jìn)入單步調(diào)試,就會(huì)出現(xiàn)你觀察一個(gè)變量值的變化時(shí),某個(gè)方法沒(méi)跟進(jìn)去,結(jié)果值就變了,不得不重來(lái)一次。
依靠后退執(zhí)行的功能,可以后退,就像下棋時(shí)悔棋那種功能一樣。當(dāng)然,這個(gè)后退操作的名字是我自己起的,在IDE里被稱(chēng)為Drop Frame。
有了這個(gè)功能,我們?cè)贒rop 了當(dāng)前這個(gè)Frame之后,已經(jīng)改變的變量值不會(huì)恢復(fù)。比如你向當(dāng)前調(diào)用方法里傳入了一個(gè)List,并且在方法中向List里添加了內(nèi)容,那在Drop到調(diào)用該方法的地方時(shí),List不會(huì)恢復(fù)到之前的狀態(tài)。
但是在該方法再次被調(diào)用時(shí),你可以觀察List什么時(shí)候被改變的,至少不需要再重跑一遍程序了。甚至你可以一言不合就后退。
3 條件斷點(diǎn)
為了調(diào)試代碼,就需要在要觀察變更的地方添加斷點(diǎn),然后小心翼翼的一步步執(zhí)行。
但是如果是在一個(gè)循環(huán)里,又或者該方法會(huì)被多線程同時(shí)調(diào)用到的時(shí)候,你小心的向下單步調(diào)試,發(fā)現(xiàn)沒(méi)有你關(guān)心的內(nèi)容,又從循環(huán)開(kāi)始處跑下來(lái),還是沒(méi)你的內(nèi)容,人就開(kāi)始煩燥起來(lái)。
其實(shí),在添加斷點(diǎn)的時(shí)候,我們可以為斷點(diǎn)增加一定的條件,這樣,在指定的條件滿足時(shí),斷點(diǎn)才會(huì)生效。
IntelliJ IDEA內(nèi),在斷點(diǎn)上右擊,會(huì)彈出如下圖的條件框,輸入指定的條件即可。
有了條件斷點(diǎn),不相關(guān),不感興趣的代碼就可以直接跳過(guò)了。
4 片斷代碼
這個(gè)沒(méi)想好用什么名字來(lái)表述。有些時(shí)候在調(diào)試過(guò)程中,忽然想招待一段與此相關(guān),但不在源文件中的代碼來(lái)觀察一下,輔助進(jìn)行問(wèn)題分析。此時(shí)你會(huì)停止程序,添加代碼然后重新跑一次嗎?
在IDEA里有一個(gè)執(zhí)行代碼片斷的功能,可以在當(dāng)前代碼的上下文內(nèi),執(zhí)行你臨時(shí)寫(xiě)的代碼。
例如,當(dāng)前方法傳入一個(gè)List,但這個(gè)方法里少一個(gè)你后面條件需要使用到的元素,此時(shí)你可以臨時(shí)使用片斷代碼執(zhí)行的功能,添加一個(gè)進(jìn)去。
注意,在IntelliJ IDEA里,這個(gè)上面紅框,像個(gè)小計(jì)算器的按鈕就是臨時(shí)執(zhí)行的功能,點(diǎn)擊之后,會(huì)彈出按鈕下方這個(gè)Evaluate Expression(Ctrl+F8)的框,輸入代碼,點(diǎn)擊右下角的Evalute即可。返回值會(huì)顯示在Result處。
這就就相當(dāng)于臨時(shí)改變了變量?jī)?nèi)容。
然后,還可以調(diào)用對(duì)象的方法,執(zhí)行功能,獲取屬性值等。
5 查看變量修改值
每個(gè)IDE在調(diào)試代碼時(shí)都提供了一個(gè)觀察當(dāng)前上下文變量值的窗口。其實(shí)除了查看之外,一些非final的基本類(lèi)型,還可以直接在此處修改值。這樣如果多次循環(huán)執(zhí)行時(shí),每次可以恢復(fù)到期望的值,不需要重啟程序。
常用代碼自動(dòng)補(bǔ)全快捷鍵
快捷鍵 | 說(shuō)明 |
---|---|
sout | System.out.println(“”); |
psvm | main方法 |
常用設(shè)置項(xiàng)
常用快捷鍵
快捷鍵 | 說(shuō)明 |
---|---|
Alt + Ctrl + S | 打開(kāi)Settings |
Alt + Ctrl + Shift + S | 打開(kāi)Project Structrue |
Alt + Enter | 快速修復(fù) |
Alt + / | 單詞自動(dòng)補(bǔ)全 |
Alt + Insert | 代碼自動(dòng)生成,比如setter、getter、toString等等 |
Alt + Shift + V | 把類(lèi)中成員移動(dòng)到另一個(gè)類(lèi) |
Ctrl + Shift + F | 格式化代碼 |
Ctrl + Shift + U | 大小寫(xiě)切換 |
Ctrl + Shift + I | 根據(jù)當(dāng)前上下文顯示代碼定義,比如:光標(biāo)停在方法上就會(huì)以popupview方式顯示該方法的定義 |
Ctrl + click | 跳到源碼 |
Shift + Shift | 搜索所有文件 |
Ctrl + E | 打開(kāi)最近訪問(wèn)文件列表 |
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java Socket編程實(shí)例(四)- NIO TCP實(shí)踐
這篇文章主要講解Java Socket編程中NIO TCP的實(shí)例,希望能給大家做一個(gè)參考。2016-06-06談?wù)勎覍?duì)Spring Bean 生命周期的理解
Spring Bean 的生命周期在整個(gè) Spring 中占有很重要的位置,掌握這些可以加深對(duì) Spring 的理解。這篇文章主要介紹了Spring Bean 生命周期,需要的朋友可以參考下2018-03-03SpringMVC統(tǒng)一異常處理實(shí)例代碼
這篇文章主要介紹了SpringMVC統(tǒng)一異常處理實(shí)例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11如何使用SpringBoot集成Kafka實(shí)現(xiàn)用戶數(shù)據(jù)變更后發(fā)送消息
Spring Boot集成Kafka實(shí)現(xiàn)用戶數(shù)據(jù)變更后,向其他廠商發(fā)送消息,我們需要考慮配置Kafka連接、創(chuàng)建Kafka Producer發(fā)送消息、監(jiān)聽(tīng)用戶數(shù)據(jù)變更事件,并將事件轉(zhuǎn)發(fā)到Kafka,本文分步驟給大家講解使用SpringBoot集成Kafka實(shí)現(xiàn)用戶數(shù)據(jù)變更后發(fā)送消息,感興趣的朋友一起看看吧2024-07-07collection集合體系與并發(fā)修改異常的解決方法
今天小編就為大家分享一篇關(guān)于collection集合體系與并發(fā)修改異常的解決方法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03Intellij IDEA 添加jar包的三種方式(小結(jié))
這篇文章主要介紹了Intellij IDEA 添加jar包的三種方式(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08Java的Hibernate框架中的雙向主鍵關(guān)聯(lián)與雙向外鍵關(guān)聯(lián)
Hibernate想要實(shí)現(xiàn)雙向的關(guān)聯(lián)就必須在映射文件的兩端同時(shí)配置<one-to-one>,另外還要在主映射的一端采用foreign外鍵關(guān)聯(lián)屬性,下面我們就一起來(lái)看一下Java的Hibernate框架中的雙向主鍵關(guān)聯(lián)與雙向外鍵關(guān)聯(lián)方法:2016-06-06Spring?MVC和springboot靜態(tài)資源處理問(wèn)題
這篇文章主要介紹了Spring?MVC和springboot靜態(tài)資源處理問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08