new HashMap()和Maps.newHashMap()的區(qū)別是什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站建設(shè)、網(wǎng)站制作、洛隆網(wǎng)絡(luò)推廣、微信小程序、洛隆網(wǎng)絡(luò)營銷、洛隆企業(yè)策劃、洛隆品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供洛隆建站搭建服務(wù),24小時服務(wù)熱線:18980820575,官方網(wǎng)址:jinyejixie.com
1、new HashMap() 這種是java原生API寫法,需要你手動加泛型。存在線程安全問題,在擴(kuò)容計算hash的時候會出現(xiàn)安全問題,在rehash方法中,有興趣的可以去看一下源碼
Map<String, Object> result = new HashMap<String,Object>();
2、Maps.newHashMap(),這種是google的guava.jar提供的寫法,目的是為了簡化代碼,不需要你手動寫泛型。挺方便的,代碼看著也挺整潔的,也存在安全問題,因?yàn)樗举|(zhì)上也是給你返回的一個HashMap(),所以安全方面和HashMap一樣
Map<String, Object> result = Maps.newHashMap();
newHashMap()源碼:
/** * Creates a <i>mutable</i>, empty {@code HashMap} instance. * * <p><b>Note:</b> if mutability is not required, use {@link * ImmutableMap#of()} instead. * * <p><b>Note:</b> if {@code K} is an {@code enum} type, use {@link * #newEnumMap} instead. * * @return a new, empty {@code HashMap} */ public static <K, V> HashMap<K, V> newHashMap() { return new HashMap<K, V>(); }
3、 Maps.newHashMapWithExpectedSize(10) 這個創(chuàng)建實(shí)例時需要設(shè)置默認(rèn)元素個數(shù),
源碼分析:
我們通過 expectedSize + expectedSize / 3 計算 10+10/3 = 13,經(jīng)過計算就會被設(shè)置為13,也就是多擴(kuò)了1/3,
當(dāng)HashMap內(nèi)部維護(hù)的哈希表的容量達(dá)到75%時(默認(rèn)情況下),會觸發(fā)rehash,而rehash的過程是比較耗費(fèi)時間的。所以初始化容量要設(shè)置成expectedSize + expectedSize / 3的話,可以有效的減少沖突也可以減小誤差。
所以,我可以認(rèn)為,當(dāng)我們明確知道HashMap中元素的個數(shù)的時候,把默認(rèn)容量設(shè)置成expectedSize + expectedSize / 3是一個在性能上相對好的選擇,但是,同時也會犧牲些內(nèi)存。
public static <K, V> HashMap<K, V> newHashMapWithExpectedSize( int expectedSize) { return new HashMap<K, V>(capacity(expectedSize)); } /** * Returns a capacity that is sufficient to keep the map from being resized as * long as it grows no larger than expectedSize and the load factor is >= its * default (0.75). */ static int capacity(int expectedSize) { if (expectedSize < 3) { checkNonnegative(expectedSize, "expectedSize"); return expectedSize + 1; } if (expectedSize < Ints.MAX_POWER_OF_TWO) { return expectedSize + expectedSize / 3; } return Integer.MAX_VALUE; // any large value }
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。
文章名稱:newHashMap()和Maps.newHashMap()的區(qū)別是什么
分享URL:http://jinyejixie.com/article42/ijghhc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、Google、品牌網(wǎng)站建設(shè)、外貿(mào)建站、定制網(wǎng)站、ChatGPT
聲明:本網(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)