本篇內(nèi)容介紹了“java中HashMap、Hashtable、ConcurrentHashMap的原理與區(qū)別”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
興寧網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)公司成立與2013年到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司。
我們先進行Hashtable與HashMap的比對:
Hashtable與HashMap,他們之間的最大的區(qū)別在與Hashtable是線程安全的,而HashMap不是線程安全的,Hashtable是在java開始發(fā)布時就提供的鍵值映射的數(shù)據(jù)結(jié)構(gòu),而HashMap產(chǎn)生于JDK1.2。現(xiàn)在Hashtable基本已經(jīng)失去了使用常見,究其原因第一可能是因為效率慢,但還有很大一部分原因估計是因為沒有遵循駝峰命名。說實話,我這個強迫癥看著他就非常難受!其他還有一些不同就是他們的父類也不一樣,HashMap是繼承自AbstractMap類,而Hashtable繼承自Dictionary類,還有就是Hashtable無論是key還是value都不能為null,實現(xiàn)線程安全的時候是鎖住整個Hashtable,效率超級低。果然,沒人用的東西必然有不可取之處。
我們再來看看ConcurrentHashMap:
hashMap與ConcurrentHashMap,他們之間的區(qū)別其實跟hashtable與hashMap的區(qū)別差不多,也是ConcurrentHashMap是線程安全的,但是hashtable是使用的是synchronized關(guān)鍵字,而ConcurrentHashMap使用的是分段鎖技術(shù),他融合了hashMap與synchronized的優(yōu)點,ConcurrentHashMap默認將hash表分為16個區(qū)間,正常的操作只需要使用到當前的區(qū)間,這樣看來,原來只能一個線程進入的,現(xiàn)在卻能16個線程同時進入,讀線程幾乎不受任何影響,寫入才會鎖定,性能的提升簡直不可同日而語。
“java中HashMap、Hashtable、ConcurrentHashMap的原理與區(qū)別”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!