小編給大家分享一下jdk源代碼的閱讀技巧,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)公司是一家專業(yè)提供龍馬潭企業(yè)網(wǎng)站建設,專注與成都做網(wǎng)站、網(wǎng)站建設、HTML5、小程序制作等業(yè)務。10年已為龍馬潭眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設計公司優(yōu)惠進行中。
凡事皆有目的,閱讀源碼也是一樣。
從大的方面來說,我們閱讀源碼的目的是為了提升自己的技術能力,運用到工作中,遇到問題快速定位,升職加薪等等。
從小的方面來說,閱讀某一段源碼的目的就是要搞清楚它的原理,就是死磕,就是那種探索真相的固執(zhí)。
目的是抽象的,目標是具體的,我們閱讀源碼之前一定要給自己設定一個目標。
比如,下一章我們將要一起學習的ConcurrentHashMap,我們可以設定以下目標:
(1)熟悉ConcurrentHashMap的存儲結構;
(2)熟悉ConcurrentHashMap中主要方法的實現(xiàn)過程;
(3)探索ConcurrentHashMap中出現(xiàn)的新技術;
有了目標之后,我們要試著提出一些問題。
還是以ConcurrentHashMap為例,筆者提出了以下這些問題:
(1)ConcurrentHashMap與HashMap的數(shù)據(jù)結構是否一樣?
(2)HashMap在多線程環(huán)境下何時會出現(xiàn)并發(fā)安全問題?
(3)ConcurrentHashMap是怎么解決并發(fā)安全問題的?
(4)ConcurrentHashMap使用了哪些鎖?
(5)ConcurrentHashMap的擴容是怎么進行的?
(6)ConcurrentHashMap是否是強一致性的?
(7)ConcurrentHashMap不能解決哪些問題?
(8)ConcurrentHashMap除了并發(fā)安全,還有哪些與HashMap不同的地方,為什么要那么實現(xiàn)?
(8)ConcurrentHashMap中有哪些不常見的技術值得學習?
很多人會說,我也知道要提出問題,但是該怎么提出問題呢?
這確實是很困難的一件事,筆者認為主要是三點:
(1)問自己
把自己當成面試官問自己,往死里問的那種。
如果問自己問不出幾個問題,也不要緊,請看下面。
(2)問互聯(lián)網(wǎng)
很多問題可能自己也想不到,那就需要上網(wǎng)大概查一下相關的博客,看人家有沒有提出什么問題。
或者,查詢相關面試題。
比如,筆者學習ConcurrentHashMap這個類時,上網(wǎng)一查很多都是基于jdk7的,那這時候就可以提出一個問題,jdk8與jdk7中ConcurrentHashMap這個類的實現(xiàn)方式有何不同?jdk8對jdk7作了哪些優(yōu)化?
(3)不斷發(fā)現(xiàn)問題
一開始提不出幾個問題也不要緊,關鍵是要看,看了才能發(fā)現(xiàn)更多的問題。
首先,一定要帶著問題閱讀源碼。
其次,一定要忽略不必要的細節(jié)。
再次,一定要死磕重要的細節(jié)。
乍一看,后面兩步似乎有所矛盾,其實不然,忽略不必要的細節(jié)是為了不迷失在源碼的世界中,死磕重要的細節(jié)是為了弄清楚源碼的真相。
這里的細節(jié)是忽略還是死磕,主要是看跟問題的相關性。
jdk源碼還是比較好閱讀的,如果后面看spring的源碼,做不到忽略不必要的細節(jié),真的是會迷失的,先埋個伏筆哈~~
舉個例子,之前閱讀過ArrayList的序列化相關的代碼中的readObject()方法。
"s.readInt();"
這行是干嘛的?省略行不行?這時候就要去了解序列化相關的知識,然后看看writeObject()里面的實現(xiàn),這就是要死磕的代碼。
"SharedSecrets.getJavaOISAccess().checkArray(s, Object[].class, capacity);"
這行又是干嘛的?乍一看,好像是跟權限相關的代碼,跟我們的問題“序列化”無關,忽略之,如果實在想知道,先打個標記,等把序列化的問題解決了再來研究這個東西。
private void readObject(java.io.ObjectInputStream s) throws java.io.IOException, ClassNotFoundException { // 聲明為空數(shù)組 elementData = EMPTY_ELEMENTDATA; // 讀入非transient非static屬性(會讀取size屬性) s.defaultReadObject(); // 讀入元素個數(shù),沒什么用,只是因為寫出的時候寫了size屬性,讀的時候也要按順序來讀 s.readInt(); if (size > 0) { // 計算容量 int capacity = calculateCapacity(elementData, size); SharedSecrets.getJavaOISAccess().checkArray(s, Object[].class, capacity); // 檢查是否需要擴容 ensureCapacityInternal(size); Object[] a = elementData; // 依次讀取元素到數(shù)組中 for (int i=0; i<size; i++) { a[i] = s.readObject(); } } }
在閱讀jdk源碼的時候,還有很重要的一點,就是要多做比較,比較也可以分為橫向比較和縱向比較。
(1)橫向比較
就是與相似的類做比較。比如,集合模塊中,基本都是各種插入、查詢、刪除元素,那這時候可以從數(shù)據(jù)結構、時間復雜度等維度進行比較,這就是橫向比較。
(2)縱向比較
可以從集合發(fā)展的歷史進行比較。比如,HashMap的發(fā)展史,從(單個數(shù)組)實現(xiàn)(沒錯,可以直接用一個數(shù)組實現(xiàn)HashMap),到(多數(shù)組+鏈表)實現(xiàn),再到jdk8中的(多數(shù)組+鏈表+紅黑樹)實現(xiàn),這就是縱向比較。
最后一步,最最最最重要的就是要多做實驗。
比如,ConcurrentHashMap是不是強一致性的?
可以啟動多個線程去不斷調用get()、put()、size()方法,看看是不是強一致性的。
這一點我不多說,大家都懂得。
不管是什么領域,耐心&堅持都是最難能可貴的品質。
閱讀源碼也是一樣,只要耐心地堅持下去,終將有所收獲。
以上是jdk源代碼的閱讀技巧的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
文章題目:jdk源代碼的閱讀技巧
本文URL:http://jinyejixie.com/article46/iisghg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供用戶體驗、品牌網(wǎng)站制作、App設計、網(wǎng)站建設、Google、ChatGPT
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)