java中的HashMap與LinkedHashMap有什么區(qū)別?針對這個(gè)問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。
創(chuàng)新互聯(lián)公司專注于北票網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供北票營銷型網(wǎng)站建設(shè),北票網(wǎng)站制作、北票網(wǎng)頁設(shè)計(jì)、北票網(wǎng)站官網(wǎng)定制、微信平臺小程序開發(fā)服務(wù),打造北票網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供北票網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
HashMap
hashMap是最常用的Map,根據(jù)鍵的HashCode值存儲數(shù)據(jù),可以根據(jù)鍵直接獲取它的值,具有很快的訪問速度,遍歷時(shí)候的順序是完全隨機(jī)的。HashMap只允許一個(gè)鍵為Null,允許多個(gè)值為Null。
特性: 完全隨機(jī)
優(yōu)點(diǎn): 隨機(jī)訪問,取值速度快
缺點(diǎn): 多個(gè)線程同時(shí)寫HashMap可能導(dǎo)致數(shù)據(jù)不一致,如果需要同步,使用Collection的synchronizedMap
方法或者使用ConcurrentHashMap
LinkedHashMap
LinkedHashMap是HashMap的一個(gè)子類,保存了記錄的插入順序,與HashMap的隨機(jī)遍歷不同,在用Iterator遍歷的時(shí)候,先得到的記錄肯定是先插入的,類似于python中的OrderedDict。
遍歷速度會比HashMap慢,不過有一種情況例外: 當(dāng)HashMap的容量很大,實(shí)際數(shù)據(jù)很少時(shí) , 因?yàn)镠ashMap的遍歷速度和它的容量有關(guān),而LinkedHashMap只跟實(shí)際數(shù)據(jù)量有關(guān)。
TreeMap
TreeMap實(shí)現(xiàn)SortMap接口,能夠?qū)⑺4娴挠涗洶存I排序,默認(rèn)是按鍵的升序排列,也可以指定排序的比較器,遍歷TreeMap的時(shí)候,得到的記錄是按照鍵排過序的。
根據(jù)數(shù)據(jù)選擇Map
一般情況下,我們用的最多的是HashMap,在Map中插入、刪除和定位元素,HashMap 是最好的選擇。但如果您要按自然順序或自定義順序遍歷鍵,那么TreeMap會更好。如果需要輸出的順序和輸入的相同,那么用LinkedHashMap可以實(shí)現(xiàn),它還可以按讀取順序來排列。
關(guān)于java中的HashMap與LinkedHashMap有什么區(qū)別問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。