凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!

同學們,你們知道學習編程最重要的是什麼嗎?沒錯,就是實踐。實踐的過程無外乎:寫代碼,看別人寫的代碼,然後在寫代碼。

拿到需求,是不是總沒有思路,凌晨3點了還在電腦前發呆?那就去看別人寫的代碼吧。

看別人寫代碼可以讓我們吸收前輩的經驗,找到編程的思路,站在巨人的肩膀上,打開自己的思維。

閱讀別人的代碼也是有技巧的,今天跟大家分享一下閱讀源碼的幾個小技巧,對於閱讀Java中間件如Spring、Dubbo等框架源碼的同學有一定幫助。

凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!

本文基於Eclipse IDE,我們每天都使用的IDE其實提供了很多強大的功能,掌握它們,往往能夠事半功倍。

1、Quick Type Hierarchy 快速查看類繼承體系。

快捷鍵:Ctrl + T


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!


查看類很多人可能都知道,可源碼閱讀的時候更多用來查看方法體系更重要,可以方便快速的定位到方法的實現類。如:


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!


此時如果想查看getBean()方法如何實現,可能會讓你失望。結果如下:


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!


進入到了BeanFactory的接口定義方法,什麼也沒有。

此時我們直接在getBean上 Ctrl+T :


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!


可以看到其實現的子類,點擊子類進去即可。此方法還適用於框架中非常常見的模板方法模式,在抽象類中定義的模板方法,用這招輕鬆找到實現類。

當然還有詳細的Open Type Hierarchy


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!


會在左側視圖裡面展示更好的Type View:


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!



2、Open Call Hierachy 打開調用層級

快捷鍵:Ctrl+Alt+H


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!


個人認為這是閱讀源碼最有用的利器,掌握它,可以輕鬆遊走於各種方法調用之間。然而從我身邊的朋友來看, 很多人都不知道他的存在。

Open Call Hierachy 查看結果如下,調用關係清晰明朗,可以直接定位到調用的地方。


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!



3、Debug 斷點的靈活使用

斷點調式時,心中必須很清楚F5、F6、F7、F8的作用,不然要麼迷失於源碼之中,要麼什麼都沒看清就走完了。

重新囉嗦一下它們的作用:

  • F5 Step Into,單步進入。進入到某個方法裡面;
  • F6 Step Over,單步結束。一行一行的執行代碼,入門時很多人只會一行一行走;
  • F7 Step Return,跳出放發。進入到某個方法裡面時,如果發現這個方法沒有你想看的東西,或者已經看到了你想看的,直接F7,跳出到方法外;
  • F8 Resume,繼續往下執行。往下執行,遇到下一個斷點時再停下來,沒有則一直運行完。

調試時我們可能會經常遇到loadClass的情況:


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!



在40行想進入ClassPathXmlApplicationContext構造方法,F5不料進入了類加載:


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!



熟悉類加載的同學會很熟悉,不熟悉類加載機制的也不要慌,這是說明你調試的類第一次被加載,這時候我們F7跳出類加載,回到40行。


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!


這個時候再按F5會真正進入ClassPathXmlApplicationContext構造方法。

當我們斷點跟蹤Spring這種源碼的時候,一定要有節奏,以優先找到整體脈絡為準,不要一直的F5進入每一行細看,F5下去,幾天都走不完Spring。能熟練在Spring這種框架中F5、F6、F7、F8,就離弄懂他不遠了。

Dubug的時候還應該注意debug視圖的線程棧:


凌晨3點了作為程序員需求還沒思路?那是你不會這項技能!


這個視圖能夠讓你在走得比較深的時候,可以一眼看出自己怎麼進來的,當前位於什麼方法裡等信息,還可以點擊對應的代碼行數進入查看。

總結,這是使用IDE跟蹤源碼的幾個小技巧,尤其是第二點,是很實用的,希望對大家在進行源碼跟蹤時有一定的幫助。



分享到:


相關文章: