12.05 我為什麼推薦IDEA?看源碼

自從拋棄eclipse之後就一直在用IDEA,其強大功能讓源碼的調試過程無比順暢。

從此,透心涼,心飛揚。

1.條件斷點

看源碼的時候,經常遇到這個情況,源碼中有個for循環,關鍵是這個list的size有時候長達數百個.但是我們只想debug一種情況.肥朝就曾經見過,在for循環中打了斷點,一直按跳過,按了數十下之後.才找到自己想debug的值.這樣效率不高

比如下文這個

如果你想debug數字10這種情況,如果你不知道條件斷點,那麼你可能要一直點9次跳過.我們來看一下條件斷點的使用

這樣,就只有滿足條件的時候才會進入斷點了,告別無效的 小手一抖!

2.強制返回值

比如SpringBoot中這個打印Banner的.我們想調試多種情況.就可以利用這個 ForceReturn,這樣方便我們調試源碼中的多種分支流程

3.模擬異常

在做業務開發中,我們有時需要模擬某個方法拋出異常,看看自己的代碼是不是像肥朝一樣可靠得一逼.但是你每次去寫死一個異常,然後再刪掉,這種低效的方式有違極客精神.那麼我們如果讓一個方法拋出異常呢?

不過要注意的一點是,這個功能印象中是IDEA 2018年以後的版本才有的功能.

4.Evaluate Expression

比如我們看源碼時遇到這個一個場景,這裡有一個 byte[],但是我們就想看一下這個的值到底是啥.

那麼我們可以這麼操作一波

這個功能的使用場景非常的廣,通過這個功能,可以在看源碼時,給某個變量賦我們要想的值,從而改變代碼的分支走向等等.總之,這個是肥朝看源碼中,使用頻率最高的功能之一.更多場景,等待 老司機們自己調教!

5.toString的坑(重點)

相信看過Dubbo源碼的朋友都會遇到過這個一個坑.也就是你把斷點打在下面圖示的第一個箭頭的時候,是無法進入 init()方法的.但是你把斷點打在第二個箭頭也就是 init()方法的時候,是能進入的.曾經也有不少人問過這個問題.

當然除了這個坑之外,也有類似的坑,如下

這個idea的默認設置.建議在一定條件下還是關閉.