干货:阅读跟踪 Java 源码的几个小技巧!
今天跟大家分享一下我平時閱讀源碼的幾個小技巧,對于閱讀Java中間件如Spring、Dubbo等框架源碼的同學(xué)有一定幫助。
本文基于Eclipse IDE,我們每天都使用的IDE其實提供了很多強大的功能,掌握它們,往往能夠事半功倍。
?
1、Quick Type Hierarchy 快速查看類繼承體系。
快捷鍵:Ctrl + T
查看類很多人可能都知道,可源碼閱讀的時候更多用來查看方法體系更重要,可以方便快速的定位到方法的實現(xiàn)類。如:
此時如果想查看getBean()方法如何實現(xiàn),可能會讓你失望。結(jié)果如下:
進入到了BeanFactory的接口定義方法,什么也沒有。
此時我們直接在getBean上 Ctrl+T :
可以看到其實現(xiàn)的子類,點擊子類進去即可。此方法還適用于框架中非常常見的模板方法模式,在抽象類中定義的模板方法,用這招輕松找到實現(xiàn)類。
當(dāng)然還有詳細(xì)的Open Type Hierarchy
會在左側(cè)視圖里面展示更好的Type View:
?
2、Open Call Hierachy 打開調(diào)用層級
快捷鍵:Ctrl+Alt+H
個人認(rèn)為這是閱讀源碼最有用的利器,掌握它,可以輕松游走于各種方法調(diào)用之間。然而從我身邊的朋友來看, 很多人都不知道他的存在。推薦大家看這篇文章《10個Eclipse珍藏插件推薦》。
Open Call Hierachy 查看結(jié)果如下,調(diào)用關(guān)系清晰明朗,可以直接定位到調(diào)用的地方。
?
3、Debug 斷點的靈活使用
斷點調(diào)試時,心中必須很清楚F5、F6、F7、F8的作用,不然要么迷失于源碼之中,要么什么都沒看清就走完了。
重新啰嗦一下它們的作用:
-
F5 Step Into,單步進入:進入到某個方法里面;
-
F6 Step Over,單步結(jié)束:一行一行的執(zhí)行代碼,入門時很多人只會一行一行走;
-
F7 Step Return,跳出方法:進入到某個方法里面時,如果發(fā)現(xiàn)這個方法沒有你想看的東西,或者已經(jīng)看到了你想看的,直接F7,跳出到方法外;
-
F8 Resume,繼續(xù)往下執(zhí)行:往下執(zhí)行,遇到下一個斷點時再停下來,沒有則一直運行完。
調(diào)試時我們可能會經(jīng)常遇到loadClass的情況:
在40行想進入ClassPathXmlApplicationContext構(gòu)造方法,F5不料進入了類加載:
熟悉類加載的同學(xué)會很熟悉,不熟悉類加載機制的也不要慌,這是說明你調(diào)試的類第一次被加載,這時候我們F7跳出類加載,回到40行。
這個時候再按F5會真正進入ClassPathXmlApplicationContext構(gòu)造方法。
當(dāng)我們斷點跟蹤Spring這種源碼的時候,一定要有節(jié)奏,以優(yōu)先找到整體脈絡(luò)為準(zhǔn),不要一直的F5進入每一行細(xì)看,F5下去,幾天都走不完Spring。
能熟練在Spring這種框架中F5、F6、F7、F8,就離弄懂他不遠(yuǎn)了。
Debug的時候還應(yīng)該注意debug視圖的線程棧:
這個視圖能夠讓你在走得比較深的時候,可以一眼看出自己怎么進來的,當(dāng)前位于什么方法里等信息,還可以點擊對應(yīng)的代碼行數(shù)進入查看。
?
總結(jié),這是我使用IDE跟蹤源碼的幾個小技巧,尤其是第二點,是很實用的,希望對大家在進行源碼跟蹤時有一定幫助。
總結(jié)
以上是生活随笔為你收集整理的干货:阅读跟踪 Java 源码的几个小技巧!的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 10个Eclipse珍藏插件推荐
- 下一篇: 理解Go 1.5 vendor