給自己立個flag:沒事就讀源代碼

給自己立個flag:

沒事就讀源代碼

 

閱讀Java源碼的前提條件:

1、技術基礎

在閱讀源碼之前,我們要有一定程度的技術基礎的支持。

假如你從來都沒有學過Java,也沒有其它編程語言的基礎,上來就啃《Core Java》,那樣是很難有收穫的,尤其是《深入Java虛擬機》這類書,或許別人覺得好,但是未必適合現在的你。

比如設計模式,許多Java源碼當中都會涉及到。再比如閱讀Spring源碼的時候,勢必要先對IOC,AOP,Java動態代理等知識點有所瞭解。

2、強烈的求知慾

強烈的求知慾是閱讀源碼的核心動力!

大多數程序員的學習態度分爲如下幾個層次:

完成自己的項目就可以了,遇到不懂的地方就百度一下。

不僅做好項目,還會去閱讀一些和項目有關的書籍。

除了閱讀和項目相關的書籍之外,還會閱讀一些IT行業相關的書籍。

平時會經常逛逛GitHub,找一些開源項目看看。

閱讀基礎框架、J2EE規範、源碼。

大多數程序員的層次都是在第一層,到第五層的人就需要有強烈的求知慾了。

3、足夠的耐心

通過閱讀源碼我們可以學習大佬的設計思路,技巧。還可以把我們一些零碎的知識點整合起來,從而融會貫通。總之閱讀源碼的好處多多,想必大家也清楚。

但是真的把那麼龐大複雜的代碼放到你的眼前時,肯定會在閱讀的過程中卡住,就如同陷入了一個巨大的迷宮,如果想要在這個巨大的迷宮中找到一條出路,那就需要把整個迷宮的整體結構弄清楚,比如:API結構、框架的設計圖。而且還有理解它的核心思想,確實很不容易。

剛開始閱讀源碼的時候肯定會很痛苦,所以,沒有足夠的耐心是萬萬不行的。

如何讀Java源碼:

團長也是經歷過閱讀源碼種種痛苦的人,算是有一些成功的經驗吧,今天來給大家分享一下。

 

如果你已經有了一年左右的Java開發經驗的話,那麼你就有閱讀Java源碼的技術基礎了。

 

1、建議從JDK源碼開始讀起,這個直接和eclipse集成,不需要任何配置。

可以從JDK的工具包開始,也就是我們學的《數據結構和算法》Java版,如List接口和ArrayList、LinkedList實現,HashMap和TreeMap等。這些數據結構裏也涉及到排序等算法,一舉兩得。

 

面試時,考官總喜歡問ArrayList和Vector的區別,你花10分鐘讀讀源碼,估計一輩子都忘不了。

 

然後是core包,也就是String、StringBuffer等。 如果你有一定的Java IO基礎,那麼不妨讀讀FileReader等類。

 

建議大家看看《Java In A Nutshell》,裏面有整個Java IO的架構圖。Java IO類庫,如果不理解其各接口和繼承關係,則閱讀始終是一頭霧水。

 

Java IO 包,我認爲是對繼承和接口運用得最優雅的案例。如果你將來做架構師,你一定會經常和它打交道,如項目中部署和配置相關的核心類開發。

 

讀這些源碼時,只需要讀懂一些核心類即可,如和ArrayList類似的二三十個類,對於每一個類,也不一定要每個方法都讀懂。像String有些方法已經到虛擬機層了(native方法),如hashCode方法。

 

當然,如果有興趣,可以對照看看JRockit的源碼,同一套API,兩種實現,很有意思的。

 

如果你再想鑽的話,不妨看看針對虛擬機的那套代碼,如System ClassLoader的原理,它不在JDK包裏,JDK是基於它的。JDK的源碼Zip包只有10來M,它像是有50來M,Sun公司有下載的,不過很隱祕。我曾經爲自己找到、讀過它很興奮了一陣。

 

2、Java Web項目源碼閱讀

步驟:表結構 → web.xml → mvc → db → spring ioc → log→ 代碼

 

① 先了解項目數據庫的表結構,這個方面是最容易忘記的,有時候我們只顧着看每一個方法是怎麼進行的,卻沒有去了解數據庫之間的主外鍵關聯。其實如果先了解數據庫表結構,再去看一個方法的實現會更加容易。

 

② 然後需要過一遍web.xml,知道項目中用到了什麼攔截器,監聽器,過濾器,擁有哪些配置文件。如果是攔截器,一般負責過濾請求,進行AOP等;如果是監聽器,可能是定時任務,初始化任務;配置文件有如 使用了spring後的讀取mvc相關,db相關,service相關,aop相關的文件。

 

③ 查看攔截器,監聽器代碼,知道攔截了什麼請求,這個類完成了怎樣的工作。有的人就是因爲缺少了這一步,自己寫了一個action,配置文件也沒有寫錯,但是卻怎麼調試也無法進入這個action,直到別人告訴他,請求被攔截了。

 

④ 接下來,看配置文件,首先一定是mvc相關的,如springmvc中,要請求哪些請求是靜態資源,使用了哪些view策略,controller註解放在哪個包下等。然後是db相關配置文件,看使用了什麼數據庫,使用了什麼orm框架,是否開啓了二級緩存,使用哪種產品作爲二級緩存,事務管理的處理,需要掃描的實體類放在什麼位置。最後是spring核心的ioc功能相關的配置文件,知道接口與具體類的注入大致是怎樣的。當然還有一些如apectj等的配置文件,也是在這個步驟中完成。

 

⑤ log相關文件,日誌的各個級別是如何處理的,在哪些地方使用了log記錄日誌。

 

⑥ 從上面幾點後知道了整個開源項目的整體框架,閱讀每個方法就不再那麼難了。

 

⑦ 當然如果有項目配套的開發文檔也是要閱讀的。

 

3、Java框架源碼閱讀

當然了,就是Spring、MyBatis這類框架。

 

在讀Spring源碼前,一定要先看看《J2EE Design and Development》這本書,它是Spring的設計思路。注意,不是中文版,中文版完全被糟蹋了。

 

想要閱讀MyBatis的源碼就要先了解它的一些概念,否則雲裏來霧裏去的什麼也不懂。有很多人會選擇去買一些書籍來幫助閱讀,當然這是可取的。那麼如果不想的話,就可以去官網查看它的介紹(MyBatis網站:http://www.mybatis.org/mybatis-3/zh/getting-started.html),團長也是按照官網上面的介紹來進行源碼閱讀的。團長認爲MyBatis的亮點就是管理SQL語句。

 

總結

沒有人一開始就可以看得懂那些源碼,我們都是從0開始的,而且沒有什麼捷徑可尋,無非就是看我們誰願意花時間去研究,誰的求知慾更強烈,誰更有耐心。閱讀源碼的過程中我們的能力肯定會提升,可以從中學到很多東西。在我們做項目的時候就會體現出來了,的確會比以前順手很多。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章