今天跟大家分享一下我平時(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),可能會讓你失望。結(jié)果如下:
進(jìn)入到了beanfactory的接口定義方法,什么也沒有。
此時(shí)我們直接在getbean上 ctrl+t :
可以看到其實(shí)現(xiàn)的子類,點(diǎn)擊子類進(jìn)去即可。此方法還適用于框架中非常常見的模板方法模式,在抽象類中定義的模板方法,用這招輕松找到實(shí)現(xiàn)類。
當(dāng)然還有詳細(xì)的open type hierarchy
會在左側(cè)視圖里面展示更好的type view:
2、open call hierachy 打開調(diào)用層級
快捷鍵:ctrl+alt+h
個(gè)人認(rèn)為這是閱讀源碼最有用的利器,掌握它,可以輕松游走于各種方法調(diào)用之間。然而從我身邊的朋友來看, 很多人都不知道他的存在。
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í)很多人只會一行一行走;
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í)我們可能會經(jīng)常遇到loadclass的情況:
在40行想進(jìn)入classpathxmlapplicationcontext構(gòu)造方法,f5不料進(jìn)入了類加載:
熟悉類加載的同學(xué)會很熟悉,不熟悉類加載機(jī)制的也不要慌,這是說明你調(diào)試的類第一次被加載,這時(shí)候我們f7跳出類加載,回到40行。
這個(gè)時(shí)候再按f5會真正進(jìn)入classpathxmlapplicationcontext構(gòu)造方法。
當(dāng)我們斷點(diǎn)跟蹤spring這種源碼的時(shí)候,一定要有節(jié)奏,以優(yōu)先找到整體脈絡(luò)為準(zhǔn),不要一直的f5進(jìn)入每一行細(xì)看,f5下去,幾天都走不完spring。能熟練在spring這種框架中f5、f6、f7、f8,就離弄懂他不遠(yuǎn)了。
dubug的時(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í)有一定幫助。如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對服務(wù)器之家網(wǎng)站的支持!