Java原始碼跟蹤閱讀技巧

Java團長_發表於2018-11-01

今天跟大家分享一下我平時閱讀原始碼的幾個小技巧,對於閱讀Java中介軟體如Spring、Dubbo等框架原始碼的同學有一定幫助。


本文基於Eclipse IDE,我們每天都使用的IDE其實提供了很多強大的功能,掌握它們,往往能夠事半功倍。

1、Quick Type Hierarchy 快速檢視類繼承體系。

快捷鍵:Ctrl + T

640?wx_fmt=png

檢視類很多人可能都知道,可原始碼閱讀的時候更多用來檢視方法體系更重要,可以方便快速的定位到方法的實現類。如:

640?wx_fmt=png

此時如果想檢視getBean()方法如何實現,可能會讓你失望。結果如下:

640?wx_fmt=png

進入到了BeanFactory的介面定義方法,什麼也沒有。

此時我們直接在getBean上 Ctrl+T :

640?wx_fmt=png

可以看到其實現的子類,點選子類進去即可。此方法還適用於框架中非常常見的模板方法模式,在抽象類中定義的模板方法,用這招輕鬆找到實現類。

當然還有詳細的Open Type Hierarchy

640?wx_fmt=png

會在左側檢視裡面展示更好的Type View:

640?wx_fmt=png

2、Open Call Hierachy 開啟呼叫層級

快捷鍵:Ctrl+Alt+H

640?wx_fmt=png

個人認為這是閱讀原始碼最有用的利器,掌握它,可以輕鬆遊走於各種方法呼叫之間。然而從我身邊的朋友來看, 很多人都不知道他的存在。

Open Call Hierachy 檢視結果如下,呼叫關係清晰明朗,可以直接定位到呼叫的地方。

640?wx_fmt=png

3、Debug 斷點的靈活使用

斷點調式時,心中必須很清楚F5、F6、F7、F8的作用,不然要麼迷失於原始碼之中,要麼什麼都沒看清就走完了。
重新囉嗦一下它們的作用:

  • F5 Step Into,單步進入。進入到某個方法裡面;

  • F6 Step Over,單步結束。一行一行的執行程式碼,入門時很多人只會一行一行走;

  • F7 Step Return,跳出放發。進入到某個方法裡面時,如果發現這個方法沒有你想看的東西,或者已經看到了你想看的,直接F7,跳出到方法外;

  • F8 Resume,繼續往下執行。往下執行,遇到下一個斷點時再停下來,沒有則一直執行完。

除錯時我們可能會經常遇到loadClass的情況:

640?wx_fmt=png

在40行想進入ClassPathXmlApplicationContext構造方法,F5不料進入了類載入:

640?wx_fmt=png

熟悉類載入的同學會很熟悉,不熟悉類載入機制的也不要慌,這是說明你除錯的類第一次被載入,這時候我們F7跳出類載入,回到40行。

640?wx_fmt=png

這個時候再按F5會真正進入ClassPathXmlApplicationContext構造方法。
當我們斷點跟蹤Spring這種原始碼的時候,一定要有節奏,以優先找到整體脈絡為準,不要一直的F5進入每一行細看,F5下去,幾天都走不完Spring。能熟練在Spring這種框架中F5、F6、F7、F8,就離弄懂他不遠了。

Dubug的時候還應該注意debug檢視的執行緒棧:

640?wx_fmt=png

這個檢視能夠讓你在走得比較深的時候,可以一眼看出自己怎麼進來的,當前位於什麼方法裡等資訊,還可以點選對應的程式碼行數進入檢視。

總結,這是我使用IDE跟蹤原始碼的幾個小技巧,尤其是第二點,是很實用的,希望對大家在進行原始碼跟蹤時有一定幫助。

PS:如果覺得我的分享不錯,歡迎大家隨手點贊、轉發。

(完)

640?

Java團長

專注於Java乾貨分享

640?wx_fmt=jpeg

掃描上方二維碼獲取更多Java乾貨

相關文章