今天介跟大家分享一下我平時閱讀源碼的幾個小技巧,對於閱讀java中間件如Spring、Dubbo等框架源碼的同學有一定幫助。 本文基於Eclipse IDE,我們每天都使用的IDE其實提供了很多強大的功能,掌握它們,往往能夠事半功倍。 1、Quick Type Hierarchy 快速查看類繼承體系 ...
今天介跟大家分享一下我平時閱讀源碼的幾個小技巧,對於閱讀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
個人認為這是閱讀源碼最有用的利器,掌握它,可以輕鬆游走於各種方法調用之間。然而從我身邊的朋友來看, 很多人都不知道他的存在。
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。能熟練在Spring這種框架中F5、F6、F7、F8,就離弄懂他不遠了。
Dubug的時候還應該註意debug視圖的線程棧:
這個視圖能夠讓你在走得比較深的時候,可以一眼看出自己怎麼進來的,當前位於什麼方法里等信息,還可以點擊對應的代碼行數進入查看。
總結,這是我使用IDE跟蹤源碼的幾個小技巧,尤其是第二點,是很實用的,希望對大家在進行源碼跟蹤時有一定幫助。