真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

jdk源代碼的閱讀技巧-創(chuàng)新互聯(lián)

小編給大家分享一下jdk源代碼的閱讀技巧,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、小程序制作、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶(hù)創(chuàng)新互聯(lián)還提供了三元免費(fèi)建站歡迎大家使用!設(shè)定目標(biāo)

凡事皆有目的,閱讀源碼也是一樣。

從大的方面來(lái)說(shuō),我們閱讀源碼的目的是為了提升自己的技術(shù)能力,運(yùn)用到工作中,遇到問(wèn)題快速定位,升職加薪等等。

從小的方面來(lái)說(shuō),閱讀某一段源碼的目的就是要搞清楚它的原理,就是死磕,就是那種探索真相的固執(zhí)。

目的是抽象的,目標(biāo)是具體的,我們閱讀源碼之前一定要給自己設(shè)定一個(gè)目標(biāo)。

比如,下一章我們將要一起學(xué)習(xí)的ConcurrentHashMap,我們可以設(shè)定以下目標(biāo):

(1)熟悉ConcurrentHashMap的存儲(chǔ)結(jié)構(gòu);

(2)熟悉ConcurrentHashMap中主要方法的實(shí)現(xiàn)過(guò)程;

(3)探索ConcurrentHashMap中出現(xiàn)的新技術(shù);

提出問(wèn)題

有了目標(biāo)之后,我們要試著提出一些問(wèn)題。

還是以ConcurrentHashMap為例,筆者提出了以下這些問(wèn)題:

(1)ConcurrentHashMap與HashMap的數(shù)據(jù)結(jié)構(gòu)是否一樣?

(2)HashMap在多線程環(huán)境下何時(shí)會(huì)出現(xiàn)并發(fā)安全問(wèn)題?

(3)ConcurrentHashMap是怎么解決并發(fā)安全問(wèn)題的?

(4)ConcurrentHashMap使用了哪些鎖?

(5)ConcurrentHashMap的擴(kuò)容是怎么進(jìn)行的?

(6)ConcurrentHashMap是否是強(qiáng)一致性的?

(7)ConcurrentHashMap不能解決哪些問(wèn)題?

(8)ConcurrentHashMap除了并發(fā)安全,還有哪些與HashMap不同的地方,為什么要那么實(shí)現(xiàn)?

(8)ConcurrentHashMap中有哪些不常見(jiàn)的技術(shù)值得學(xué)習(xí)?

如何提出問(wèn)題

很多人會(huì)說(shuō),我也知道要提出問(wèn)題,但是該怎么提出問(wèn)題呢?

這確實(shí)是很困難的一件事,筆者認(rèn)為主要是三點(diǎn):

(1)問(wèn)自己

把自己當(dāng)成面試官問(wèn)自己,往死里問(wèn)的那種。

如果問(wèn)自己?jiǎn)柌怀鰩讉€(gè)問(wèn)題,也不要緊,請(qǐng)看下面。

(2)問(wèn)互聯(lián)網(wǎng)

很多問(wèn)題可能自己也想不到,那就需要上網(wǎng)大概查一下相關(guān)的博客,看人家有沒(méi)有提出什么問(wèn)題。

或者,查詢(xún)相關(guān)面試題。

比如,筆者學(xué)習(xí)ConcurrentHashMap這個(gè)類(lèi)時(shí),上網(wǎng)一查很多都是基于jdk7的,那這時(shí)候就可以提出一個(gè)問(wèn)題,jdk8與jdk7中ConcurrentHashMap這個(gè)類(lèi)的實(shí)現(xiàn)方式有何不同?jdk8對(duì)jdk7作了哪些優(yōu)化?

(3)不斷發(fā)現(xiàn)問(wèn)題

一開(kāi)始提不出幾個(gè)問(wèn)題也不要緊,關(guān)鍵是要看,看了才能發(fā)現(xiàn)更多的問(wèn)題。

帶著問(wèn)題閱讀源碼,忽略不必要的細(xì)節(jié),死磕重要的細(xì)節(jié)

首先,一定要帶著問(wèn)題閱讀源碼。

其次,一定要忽略不必要的細(xì)節(jié)。

再次,一定要死磕重要的細(xì)節(jié)。

乍一看,后面兩步似乎有所矛盾,其實(shí)不然,忽略不必要的細(xì)節(jié)是為了不迷失在源碼的世界中,死磕重要的細(xì)節(jié)是為了弄清楚源碼的真相。

這里的細(xì)節(jié)是忽略還是死磕,主要是看跟問(wèn)題的相關(guān)性。

jdk源碼還是比較好閱讀的,如果后面看spring的源碼,做不到忽略不必要的細(xì)節(jié),真的是會(huì)迷失的,先埋個(gè)伏筆哈~~

舉個(gè)例子,之前閱讀過(guò)ArrayList的序列化相關(guān)的代碼中的readObject()方法。

"s.readInt();"這行是干嘛的?省略行不行?這時(shí)候就要去了解序列化相關(guān)的知識(shí),然后看看writeObject()里面的實(shí)現(xiàn),這就是要死磕的代碼。

"SharedSecrets.getJavaOISAccess().checkArray(s, Object[].class, capacity);"這行又是干嘛的?乍一看,好像是跟權(quán)限相關(guān)的代碼,跟我們的問(wèn)題“序列化”無(wú)關(guān),忽略之,如果實(shí)在想知道,先打個(gè)標(biāo)記,等把序列化的問(wèn)題解決了再來(lái)研究這個(gè)東西。

private void readObject(java.io.ObjectInputStream s)
        throws java.io.IOException, ClassNotFoundException {
    // 聲明為空數(shù)組
    elementData = EMPTY_ELEMENTDATA;

    // 讀入非transient非static屬性(會(huì)讀取size屬性)
    s.defaultReadObject();

    // 讀入元素個(gè)數(shù),沒(méi)什么用,只是因?yàn)閷?xiě)出的時(shí)候?qū)懥藄ize屬性,讀的時(shí)候也要按順序來(lái)讀
    s.readInt();

    if (size > 0) {
        // 計(jì)算容量
        int capacity = calculateCapacity(elementData, size);
        SharedSecrets.getJavaOISAccess().checkArray(s, Object[].class, capacity);
        // 檢查是否需要擴(kuò)容
        ensureCapacityInternal(size);
        
        Object[] a = elementData;
        // 依次讀取元素到數(shù)組中
        for (int i=0; i多做比較

在閱讀jdk源碼的時(shí)候,還有很重要的一點(diǎn),就是要多做比較,比較也可以分為橫向比較和縱向比較。

(1)橫向比較

就是與相似的類(lèi)做比較。比如,集合模塊中,基本都是各種插入、查詢(xún)、刪除元素,那這時(shí)候可以從數(shù)據(jù)結(jié)構(gòu)、時(shí)間復(fù)雜度等維度進(jìn)行比較,這就是橫向比較。

(2)縱向比較

可以從集合發(fā)展的歷史進(jìn)行比較。比如,HashMap的發(fā)展史,從(單個(gè)數(shù)組)實(shí)現(xiàn)(沒(méi)錯(cuò),可以直接用一個(gè)數(shù)組實(shí)現(xiàn)HashMap),到(多數(shù)組+鏈表)實(shí)現(xiàn),再到j(luò)dk8中的(多數(shù)組+鏈表+紅黑樹(shù))實(shí)現(xiàn),這就是縱向比較。

多做實(shí)驗(yàn)

最后一步,最最最最重要的就是要多做實(shí)驗(yàn)。

比如,ConcurrentHashMap是不是強(qiáng)一致性的?

可以啟動(dòng)多個(gè)線程去不斷調(diào)用get()、put()、size()方法,看看是不是強(qiáng)一致性的。

耐心&堅(jiān)持

這一點(diǎn)我不多說(shuō),大家都懂得。

不管是什么領(lǐng)域,耐心&堅(jiān)持都是最難能可貴的品質(zhì)。

閱讀源碼也是一樣,只要耐心地堅(jiān)持下去,終將有所收獲。

以上是jdk源代碼的閱讀技巧的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


分享標(biāo)題:jdk源代碼的閱讀技巧-創(chuàng)新互聯(lián)
文章轉(zhuǎn)載:http://weahome.cn/article/dehisp.html

其他資訊

在線咨詢(xún)

微信咨詢(xún)

電話咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部