關於JDK源碼:我想聊聊如何更高效地閱讀


簡介

大家好,我是彤哥,今天我想和大家再聊聊JDK源碼的幾個問題:

  • 為什么要看JDK源碼

  • JDK源碼的閱讀順序

  • JDK源碼的閱讀方法

為什么要看JDK源碼

一,JDK源碼是其它所有源碼的基礎,看懂了JDK源碼再看其它的源碼會達到事半功倍的效果。

二,JDK源碼中包含大量的數據結構知識,是學習數據結構很好的資料,比如,鏈表、隊列、散列表、紅黑樹、跳表、桶、堆、雙端隊列等。

三、JDK源碼中包含大量的設計模式,是學習設計模式很好的資料,比如,適配器模式、模板方法模式、裝飾器模式、迭代器模式、代理模式、工廠模式、命令模式、狀態模式等。

三,JDK源碼中包含大量Java的高階知識,比如弱引用、Unsafe、CAS、鎖原理、偽共享等,不看源碼是很難學會這些知識的。

四,面試時更好地收割offer,這可能是很多同學最初的想法,其實真正看多了源碼,這一點可能並不是太重要了,因為你會發現更廣闊的世界。

五,彤哥認為最重要的,閱讀源碼是對思維的一種鍛煉,是學習優秀設計的最佳途徑,本文來源於工從號彤哥讀源碼。

JDK源碼的閱讀順序

首先,JDK源碼我分成了以下幾個部分:

基礎類

基礎類,是指組成JDK源碼地基的一部分類。

比如包裝類、反射類、工具類等,這些類有個共同點,就是代碼邏輯相對簡單,不存在數據結構、復雜運算等問題。

對於基礎類,彤哥的建議是自己從頭到尾瀏覽一遍,對於看不懂的地方可以寫測試用例或者上網查查資料。比如,Integer里面有個IntegerCache內部類你可能不知道干嘛的,這時候光看代碼是沒用的,只能上網查查資料了,也不能盲目地死磕。

簡單集合

簡單集合,是指不存在多線程安全問題的集合。

這部分集合一般用在單線程中,或者方法體中,但是他們用到了很多的數據結構,所以需要一定的數據結構知識。

對於簡單集合,彤哥的建議是先弄明白底層的數據結構知識,再去看源碼,這樣可能會輕松一些。當然,彤哥后面也會出數據結構系列的。

原子類

原子類,是指在多線程環境下能夠保證原子性的類。

這部分類主要包括Atomic*開頭和*Adder結尾的類,位於juc下面的atomic包中。

對於原子類,彤哥的建議是先去了解底層的Unsafe、CAS、偽共享等概念,再去看最簡單的AtomicInteger,最后再看LongAdder這種復雜的類。其中,斷點調試是不可或缺的手段。

說句實話,LongAdder這個類能學到很多高階的知識,非常推薦把這個類研究透徹,后面再去看Disruptor、Netty等源碼會事半功倍。

同步器

同步器,是指為了控制多個線程的競爭關系而存在的類或者關鍵字等,本文來源於工從號彤哥讀源碼,它們可以說是Java中最重要的內容,沒有它們就無法控制多線程的正常運轉。

這部分內容主要包括synchronized關鍵字、volatile關鍵字、重入鎖、讀寫鎖、倒計時器、信號量、回環柵欄、階段器、分布式鎖的實現等等。

對於同步器,彤哥的建議是先了解內存模型、可見性、原子性、有序性、Happens-Before等基本概念,再嘗試閱讀這部分的源碼,最后再歸納出屬於你自己理解的“同步器的原理”。

並發集合

並發集合,是指多線程環境下能夠保證數據一致性的集合。

這部分集合主要是運用在多線程環境下,只有極個別類牽涉到高級的數據結構,更多的是鎖、CAS、volatile、自旋等高階技巧的運用。

對於並發集合,彤哥的建議有三點:

  • 一定要在同步器之后閱讀

  • 數據結構先搞透,比如ConcurrentSkipList

  • 利用IDEA的Thread級別的斷點,不斷調試,不斷調試,不斷調試

線程(池)類

線程(池)類,是指跟線程和線程池相關的類。

這部分類主要包含Thread、ThreadLocal、三種線程池等。

對於線程(池)類,彤哥的建議是先從整體上把握,再分成幾個塊來看,看哪塊的東西就只看那塊的東西,不要管其它的代碼,即要搞清楚你的重點在哪里,比如,看線程運行的流程就不要管狀態的事,凡是牽涉到狀態的代碼全部跳過,反之亦然,都看完了,再串一起看。

IO/NIO類

IO類,是指跟輸入輸出流相關的類,這部分類主要包括文件操作相關的類以及網絡IO相關的類。

對於IO類,彤哥的建議是簡單瀏覽,做到心里有數即可,用到的時候再去查都可以。

但是對於nio相關的類,還是要好好研究的,這部分類我們放在Netty源碼閱讀的相關章節中一起學習。

其它類

其它類,工作中遇到了可以點進去看看,但是不建議抽出時間單獨去研究,比如,時間類、awt類,看的必要性不是很大。

JDK源碼的閱讀方法

一,設定目標,目標越明確越好,不要設定得過於虛無縹緲。比如,熟悉HashMap的數據結構,這就是一個很明確的目標;再比如,看懂HashMap的源碼,這就很縹緲了。

二,嘗試自己提出問題,先自己根據某個知識點發散提出問題。比如,關於HashMap你能想到哪些知識點,這部分可以借助思維導圖無限想象,后面有機會彤哥給大家分享一下思維導圖聯想法。

三,嘗試網絡查詢問題,打開度娘,輸入你要學習的知識點,把前面幾頁統統點開,看看別人都遇到了哪些問題,當然,能力強的同學也可以使用Google,這部分查詢出來的問題也可以補充到你的思維導圖中去。

四,嘗試閱讀源碼,對於上面的問題,一個一個嘗試去源碼中尋找答案,由點及面,最后再總結整個大的知識點。

五,不斷發現問題,在閱讀源碼的過程中可能又會發現新的問題,先跳過去,而是把它加到思維導圖中,等當前的問題解決完了再去解決。

六,專注你的問題,在閱讀源碼的時候一定要專注於你當前的問題,不要受其它問題的干擾,比如看線程池任務執行的流程,你就不要管線程池狀態的事情。

七,多做比較,橫向比較和縱向比較,從多維度去比較,本文來源於工從號彤哥讀源碼。

八,多做實驗,多多利用IDE的調試模式,不斷修改斷點,不斷調試。

九,多與人交流,如果條件允許的話,多與周邊的人一起交流,當然,也可以來騷擾彤哥。

十,多做總結,對於自己解決的問題,一定要學會總結,多做學習筆記,當然,也歡迎來彤哥這里投稿。

十一,耐心&堅持,閱讀源碼是一件非常枯燥而且枯燥的事情,一定要堅持堅持堅持。

總結

今天,我們聊了聊學習JDK源碼的幾個問題,不小心就寫了這么多,都是肺腑之言,希望大家能收下我的膝蓋。

彩蛋

最后,送上一幅JDK源碼的思維導圖,標星是彤哥建議必看的部分,對於時間充足的同學,沒標星當然最好也看看。

關於JDK源碼的部分彤哥已經全部解析完畢,點擊公眾號彤哥讀源碼左下角“JDK源碼”可以查看所有源碼解析。

jdk_source


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM