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