乾貨:閱讀跟蹤 Java 原始碼的幾個小技巧!
今天跟大家分享一下我平時閱讀原始碼的幾個小技巧,對於閱讀Java中介軟體如Spring、Dubbo等框架原始碼的同學有一定幫助。
本文基於Eclipse IDE,我們每天都使用的IDE其實提供了很多強大的功能,掌握它們,往往能夠事半功倍。
1、Quick Type Hierarchy 快速檢視類繼承體系。
快捷鍵:Ctrl + T
檢視類很多人可能都知道,可原始碼閱讀的時候更多用來檢視方法體系更重要,可以方便快速的定位到方法的實現類。如:
此時如果想檢視getBean()方法如何實現,可能會讓你失望。結果如下:
進入到了BeanFactory的介面定義方法,什麼也沒有。
此時我們直接在getBean上 Ctrl+T :
可以看到其實現的子類,點選子類進去即可。此方法還適用於框架中非常常見的模板方法模式,在抽象類中定義的模板方法,用這招輕鬆找到實現類。
當然還有詳細的Open Type Hierarchy
會在左側視圖裡面展示更好的Type View:
2、Open Call Hierachy 開啟呼叫層級
快捷鍵:Ctrl+Alt+H
個人認為這是閱讀原始碼最有用的利器,掌握它,可以輕鬆遊走於各種方法呼叫之間。然而從我身邊的朋友來看, 很多人都不知道他的存在。推薦大家看這篇文章《10個Eclipse珍藏外掛推薦》。
Open Call Hierachy 檢視結果如下,呼叫關係清晰明朗,可以直接定位到呼叫的地方。
3、Debug 斷點的靈活使用
斷點調式時,心中必須很清楚F5、F6、F7、F8的作用,不然要麼迷失於原始碼之中,要麼什麼都沒看清就走完了。
重新囉嗦一下它們的作用:
F5 Step Into,單步進入。進入到某個方法裡面;
F6 Step Over,單步結束。一行一行的執行程式碼,入門時很多人只會一行一行走;
F7 Step Return,跳出放發。進入到某個方法裡面時,如果發現這個方法沒有你想看的東西,或者已經看到了你想看的,直接F7,跳出到方法外;
F8 Resume,繼續往下執行。往下執行,遇到下一個斷點時再停下來,沒有則一直執行完。
除錯時我們可能會經常遇到loadClass的情況:
在40行想進入ClassPathXmlApplicationContext構造方法,F5不料進入了類載入:
熟悉類載入的同學會很熟悉,不熟悉類載入機制的也不要慌,這是說明你除錯的類第一次被載入,這時候我們F7跳出類載入,回到40行。
這個時候再按F5會真正進入ClassPathXmlApplicationContext構造方法。
當我們斷點跟蹤Spring這種原始碼的時候,一定要有節奏,以優先找到整體脈絡為準,不要一直的F5進入每一行細看,F5下去,幾天都走不完Spring。推薦大家看這篇文章《10個Eclipse珍藏外掛推薦》。
能熟練在Spring這種框架中F5、F6、F7、F8,就離弄懂他不遠了。
Debug的時候還應該注意debug檢視的執行緒棧:
這個檢視能夠讓你在走得比較深的時候,可以一眼看出自己怎麼進來的,當前位於什麼方法裡等資訊,還可以點選對應的程式碼行數進入檢視。
總結,這是我使用IDE跟蹤原始碼的幾個小技巧,尤其是第二點,是很實用的,希望對大家在進行原始碼跟蹤時有一定幫助。