是否需要去閱讀源代碼?
閱讀源碼是每個優秀開發工程師的必經之路,那么這篇文章就來講解下為什么要閱讀源碼以及如何閱讀源碼。
首先來說下為什么要讀源碼,有學習源碼的必要嗎?
為什么要閱讀源碼?
關于為什么閱讀和學習源碼,我個人認為可能有以下幾點:
(一)吊打面試官,應對面試
為了找到更好的工作,應對面試,因為在面試中肯定會問到源碼級別的問題,比如:為什么 HashMap 是線程不安全的?
如果你沒有閱讀過源碼,面試官可能會對回答的結果不滿意,進而導致面試結果不太理想,但如果你對源碼有所研究,并能夠很好地問答面試官的問題,這可能就是你的加分點,可以形成自己獨特的競爭力,吊打面試官,升職加薪不是夢。
(二)解決問題(bug)
在開發過程中,我們或多或少會遇到 bug,比如:在 foreach 循環里進行元素的 remove/add 操作,為啥有可能會報 ConcurrentModificationException 異常?
我們可以先在 Google、Stack Overflow 以及對應項目的 Issues 里看有沒有類似問題以及解決辦法,如果沒有的話,我們只能通過閱讀源碼的方式去解決了。如果我們對相關源碼有所涉獵,就可以快速定位到問題所在。
(三)提升編程能力
讀一本好書,就是和許多高尚的人談話。 -歌德
和閱讀一本好書一樣,閱讀源碼就是和編程大牛面對面交流的機會,在許多優秀的開源項目中,它們的編碼規范和架構設計都是很棒的,另外在設計上也使用了大量的設計模式,通過閱讀和學習源碼,能夠快速提升我們的編碼水平,以及對設計模式有更深的理解。
同時,在我們閱讀完一個源碼后,可以觸類旁通,能夠快速地對其他框架的源碼進行閱讀和學習,減少時間成本。
除了上述提到的原因之外,可能還有許多,在這里就不一一贅述了,那么在確定了要閱讀源碼之后,就讓我們看下如何閱讀源碼吧!
如何閱讀源碼?
如何閱讀源碼取決于你為什么要讀源碼,比如:
如果為了應對面試,那就可以圍繞常考的基礎類、集合類、隊列、線程、鎖等內容進行閱讀和學習;如果是為了解決 bug,那么就可以只圍繞出現問題的相關類進行閱讀分析,隨著解決 bug 的增多,我相信閱讀的源碼也會越多,從而更容易去閱讀和學習源碼;下面大概說下閱讀源碼的幾點建議:
在閱讀之前,可以先從開源項目的官網上看它的架構設計和功能文檔,了解這個項目的整體架構、模塊組成以及各個模塊之間的聯系。
如果沒有對應的項目文檔,可以根據代碼的模塊進行梳理,以形成對項目的初步了解,或者查看已有的源碼解析文章或者書籍,在閱讀源碼之前,了解項目的架構和思路會使閱讀源碼事半功倍。
在了解一個類的時候,可以使用 ctrl+F12 來查看類中的成員變量和方法。
可以通過 IDEA 的 Diagrams 功能去了解一個類的繼承關系。
多打斷點調試,斷點追蹤源碼是很好的閱讀源碼的方式,可以先通過 debug 了解下調用邏輯,都和哪些類有關聯,有大致了解后再通過 debug 了解整體代碼的功能實現,各個類都起到了什么作用,有沒有涉及到設計模式等。
另外,優秀的開源項目中肯定會有許多地方應用到了設計模式,建議在閱讀源碼之前,需要對常用的設計模式有大致的了解,不然閱讀源碼的效率會大大降低。
如果遇到讀不懂某部分源碼的時候,可以先跳過,之后再回來看,如果屬于搞不懂這部分就茶不思飯不想的人,可以在網上找是否有該部分源碼的解析或者文檔,也可以自己通過源碼注釋和測試用例去閱讀學習。
一般優秀的開源項目都會有單元測試,可以通過對應類的單元測試去了解方法的含義和用法,加深對源碼邏輯的理解。
在閱讀源碼的時候,可以在代碼上加上注釋和總結,同時還可以畫出時序圖和類圖,這樣對閱讀源碼有很大的幫助,可以很清楚地知道類之間的調用關系和依賴關系,也方便以后回顧,重新閱讀。
在這里推薦大家一個 IDEA 插件 SequenceDiagram,可以根據源碼生成調用時序圖,便于閱讀源碼。
剛開始閱讀源碼,不建議直接看框架源碼,可以先從 jdk 源碼看起:
jdk 源碼也是非常龐大的,可以分模塊來閱讀,下面是建議的閱讀順序:
java.lang 包下的基本包裝類(Integer、Long、Double、Float 等),還有字符串相關類(String、StringBuffer、StringBuilder 等)、常用類(Object、Exception、Thread、ThreadLocal 等)。java.lang.ref 包下的引用類(WeakReference、SoftReference 等)java.lang.annotation 包下的注解的相關類java.lang.reflect 包下的反射的相關類java.util 包下為一些工具類,主要由各種容器和集合類(Map、Set、List 等)java.util.concurrent 為并發包,主要是原子類、鎖以及并發工具類java.io 和 java.nio 可以結合著看java.time 主要包含時間相關的類,可以學習下 Java 8 新增的幾個java.net 包下為網絡通信相關的類,可以閱讀下 Socket 和 HTTPClient 相關代碼其他包下的代碼也可以做下了解,JDK源碼閱讀筆記:https://github.com/wupeixuan/JDKSourceCode1.8
再有了一定的源碼閱讀經驗后,可以再去學習 Spring、Spring Boot、Dubbo、Spring Cloud 等框架的源碼。
總結主要介紹了為什么讀源碼以及如何讀源碼,供大家參考,每個人都有適合自己的閱讀源碼的方式,希望可以在學習中去摸索出一套屬于自己的方式。
閱讀源碼不是一蹴而就的,這是持久戰,只要你能夠堅持下來,肯定受益匪淺。閱讀源碼的過程比較枯燥,可以在社群里一起討論學習,這樣可能效率更高些。
寫得不好的或者大家有什么更好的建議,也歡迎留言討論。