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
個人認為這是閱讀原始碼最有用的利器,掌握它,可以輕鬆遊走於各種方法呼叫之間。然而從我身邊的朋友來看, 很多人都不知道他的存在。
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跟蹤原始碼的幾個小技巧,尤其是第二點,是很實用的,希望對大家在進行原始碼跟蹤時有一定幫助。
PS:如果覺得我的分享不錯,歡迎大家隨手點贊、轉發。
(完)
Java團長
專注於Java乾貨分享
掃描上方二維碼獲取更多Java乾貨
相關文章
- [20211013]閱讀ldd原始碼跟蹤.txt原始碼
- 原始碼閱讀技巧篇原始碼
- IDEA閱讀原始碼的技巧Idea原始碼
- 如何閱讀Java原始碼?Java原始碼
- 【原始碼閱讀】AndPermission原始碼閱讀原始碼
- java 8 HashMap 原始碼閱讀JavaHashMap原始碼
- 15個小技巧,助你原始碼閱讀事半功倍原始碼
- 模版匹配定位跟蹤原始碼原始碼
- Java類載入原始碼閱讀Java原始碼
- Spring 6 原始碼編譯和高效閱讀原始碼技巧分享Spring原始碼編譯
- 【原始碼閱讀】Glide原始碼閱讀之with方法(一)原始碼IDE
- 【原始碼閱讀】Glide原始碼閱讀之into方法(三)原始碼IDE
- [原始碼分析] OpenTracing之跟蹤Redis原始碼Redis
- IDEA之如何Debug原始碼跟蹤Idea原始碼
- spring security 認證原始碼跟蹤Spring原始碼
- java8LinkedList原始碼閱讀解析Java原始碼
- 【原始碼閱讀】Glide原始碼閱讀之load方法(二)原始碼IDE
- PostgreSQL 原始碼解讀(15)- Insert語句(執行過程跟蹤)SQL原始碼
- 原始碼閱讀之Java棧的實現原始碼Java
- ReactorKit原始碼閱讀React原始碼
- Vollery原始碼閱讀(—)原始碼
- NGINX原始碼閱讀Nginx原始碼
- ThreadLocal原始碼閱讀thread原始碼
- 原始碼閱讀-HashMap原始碼HashMap
- Runtime 原始碼閱讀原始碼
- RunLoop 原始碼閱讀OOP原始碼
- AmplifyImpostors原始碼閱讀原始碼
- stack原始碼閱讀原始碼
- CountDownLatch原始碼閱讀CountDownLatch原始碼
- fuzz原始碼閱讀原始碼
- HashMap 原始碼閱讀HashMap原始碼
- delta原始碼閱讀原始碼
- AQS原始碼閱讀AQS原始碼
- Mux 原始碼閱讀UX原始碼
- ConcurrentHashMap原始碼閱讀HashMap原始碼
- HashMap原始碼閱讀HashMap原始碼
- PostgreSQL 原始碼解讀(3)- 如何閱讀原始碼SQL原始碼
- JDK原始碼閱讀:String類閱讀筆記JDK原始碼筆記