欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何閱讀jdk源碼?-創(chuàng)新互聯(lián)

簡介

這篇文章主要講述jdk本身的源碼該如何閱讀,關(guān)于各種框架的源碼閱讀我們后面再一起探討。

站在用戶的角度思考問題,與客戶深入溝通,找到呼圖壁網(wǎng)站設(shè)計(jì)與呼圖壁網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站制作、成都網(wǎng)站建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名與空間、虛擬主機(jī)、企業(yè)郵箱。業(yè)務(wù)覆蓋呼圖壁地區(qū)。

筆者認(rèn)為閱讀源碼主要包括下面幾個步驟。

設(shè)定目標(biāo)

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

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

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

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

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

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

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

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

提出問題

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

還是以ConcurrentHashMap為例,筆者提出了以下這些問題:

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

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

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

(4)ConcurrentHashMap使用了哪些鎖?

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

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

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

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

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

如何提出問題

很多人會說,我也知道要提出問題,但是該怎么提出問題呢?

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

(1)問自己

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

如果問自己問不出幾個問題,也不要緊,請看下面。

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

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

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

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

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

在源碼閱讀的過程中,可能看著看著就遇到個問題,這是非常常見的,這種問題也應(yīng)該保留下來研究研究。

比如,ConcurrentHashMap中size()方法是怎么實(shí)現(xiàn)的?@sun.misc.Contended這玩意是什么鬼東西?然后上網(wǎng)一查,與是為了避免偽共享,我X,偽共享又是啥?然后你再查一下偽共享,又出來了CPU多級緩存?學(xué)完CPU多級緩存,是不是覺得跟jvm的內(nèi)存模型很像?問完這一連串問題,是不是感覺世界都清晰了?^_^

看吧,問題是源源不斷地被發(fā)現(xiàn)的。

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

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

首先,一定要帶著問題閱讀源碼。

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

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

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

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

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

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

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

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

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

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

    // 讀入元素個數(shù),沒什么用,只是因?yàn)閷懗龅臅r候?qū)懥藄ize屬性,讀的時候也要按順序來讀
    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<size; i++) {
            a[i] = s.readObject();
        }
    }
}

多做比較

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

(1)橫向比較

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

(2)縱向比較

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

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

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

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

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

耐心&堅(jiān)持

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

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

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

彩蛋

哎呀,一不小心透露了下一章ConcurrentHashMap的內(nèi)容。

大家可以用本篇所說的方法試著閱讀一下ConcurrentHashMap的源碼,下一章我們再一起學(xué)習(xí)哈哈~~


如何閱讀jdk源碼?

創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務(wù)器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務(wù)器買多久送多久。

新聞標(biāo)題:如何閱讀jdk源碼?-創(chuàng)新互聯(lián)
轉(zhuǎn)載來于:http://aaarwkj.com/article12/ggjgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)標(biāo)簽優(yōu)化、云服務(wù)器、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站排名、面包屑導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
韩国三级福利在线观看| av剧情在线观看免费| 亚洲一区二区三区黄色| 国产色综合一区二区| 天堂av一区二区在线播放| 亚洲黄色av乱码在线观看| 国产精品亚洲欧美日韩在线播放| 亚洲精品熟女国产中文| 亚洲成人永久免费精品| 亚洲欧美半夜激情一区二区| 日韩欧美一区二区不卡在线| 日本精品视频一区二区三区| 日本午夜熟女九色视频| 午夜精品三级一区二区三区| 久久精品视频就在久久| 久久精品国产亚洲av不卡| 精品亚洲午夜久久久久| 91人妻成人精品一区二区| 成人作爱视频免费播放| 亚洲精品午夜久久久av| 日本福利影院在线观看| 欧美日韩国产另类久久| 欧美 日韩一区二区在线| 日韩av裸体在线播放| 日本福利一区二区三区| 国产黄色av网站在线| 五十路八十路息与子交尾| 欧美私人影院—区二区日本| 亚洲国产偷拍在线观看| 国产精品白浆大屁股一区二区三| 国产91九色蝌蚪在线观看| 91桃色午夜福利视频| 蜜桃臀内射一区二区三区| 亚洲欧洲久久激情久av| 国产精品国产三级国产av丨| 中文字幕人妻出轨一区二区 | 在线日韩观看免费av| 91精品国产自产永久在线| 九九视频在线观看免费观看| 天天操操操操操操夜夜爽| 日韩精品91一区二区|