文章詳情頁
Java中HashMap的初始容量設置方式
瀏覽:7日期:2022-08-10 11:09:13
Java中HashMap的初始容量設置
根據(jù)阿里巴巴Java開發(fā)手冊上建議HashMap初始化時設置已知的大小,如果不超過16個,那么設置成默認大小16:
集合初始化時, 指定集合初始值大小。
說明:
HashMap使用HashMap(int initialCapacity)初始化
正例:
initialCapacity = (需要存儲的元素個數(shù) / 負載因子) + 1。注意負載因子(即loader factor)默認為0.75, 如果暫時無法確定初始值大小,請設置為16(即默認值)。
反例:
HashMap需要放置1024個元素,由于沒有設置容量初始大小,隨著元素不斷增加,容量7次被迫擴大,resize需要重建hash表,嚴重影響性能。
而對于為什么負載因子是0.75,答案可以在《數(shù)據(jù)結構與算法分析 Java語言描述》的散列章節(jié)中找到
Java HashMap的指定初始值大小和自動擴容HashMap指定初始值大小指定初始值大小應為2的冪。
如果指定的初始值不是2的冪,則HashMap的容量為大于指定初始值的2的冪;如果不指定,容量默認為16。
HashMap自動擴容當HashMap的鍵值對個數(shù)大于容量的75%時,HashMap的容量擴大一倍。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。
標簽:
Java
相關文章:
1. php測試程序運行速度和頁面執(zhí)行速度的代碼2. ASP中常用的22個FSO文件操作函數(shù)整理3. 三個不常見的 HTML5 實用新特性簡介4. Warning: require(): open_basedir restriction in effect,目錄配置open_basedir報錯問題分析5. ASP調用WebService轉化成JSON數(shù)據(jù),附json.min.asp6. SharePoint Server 2019新特性介紹7. React+umi+typeScript創(chuàng)建項目的過程8. 無線標記語言(WML)基礎之WMLScript 基礎第1/2頁9. ASP.NET Core 5.0中的Host.CreateDefaultBuilder執(zhí)行過程解析10. php網絡安全中命令執(zhí)行漏洞的產生及本質探究
排行榜
