【推薦】集合初始化時,指定集合初始值大小。 說明:HashMap 使用 HashMap(int initialCapacity) 初始化, 正例:initialCapacity = (需要存儲的元素個數(shù) / 負載因子) 1。注意負載因子(即 loader factor)默認為 0.75,如果暫時無法確定初始值大小,請設置為 16(即默認值)。 反例:HashMap 需要放置 1024 個元素,由于沒有設置容量初始大小,隨著元素不斷增加,容 量 7 次被迫擴大,resize 需要重建 hash 表,嚴重影響性能。 【推薦】使用 entrySet 遍歷 Map 類集合 KV,而不是 keySet 方式進行遍歷。 說明:keySet 其實是遍歷了 2 次,一次是轉為 Iterator 對象,另一次是從 hashMap 中取出 key 所對應的 value。而 entrySet 只是遍歷了一次就把 key 和 value 都放到了 entry 中,效 率更高。 如果是 JDK8,使用 Map.foreach 方法。 正例:values()返回的是 V 值集合,是一個 list 集合對象;keySet()返回的是 K 值集合,是 一個 Set 集合對象; entrySet()返回的是 K-V 值組合集合。 【參考】利用 Set 元素唯一的特性,可以快速對一個集合進行去重操作,避免使用 List 的 contains 方法進行遍歷、對比、去重操作。 【推薦】高度注意 Map 類集合 K/V 能不能存儲 null 值的情況: 如下表格: 反例: 由于 HashMap 的干擾,很多人認為 ConcurrentHashMap 是可以置入 null 值,而事實上, 存儲 null 值時會拋出 NPE 異常。 public static void main(String[] args) { Map<String, String> map = new HashMap<>(16); map.put("101", "張三"); map.put("102", "李四"); map.put("103", "王五"); /*遍歷map集合的第一種方式:通過key獲取value*/ System.out.println("========通過key獲取value============"); // 獲取所有的key Set<String> keySet = map.keySet(); Iterator<String> iterator = keySet.iterator(); while (iterator.hasNext()) { String key = iterator.next(); // 通過key獲取value String value = map.get(key); System.out.println(key ":" value); } System.out.println("========獲取所有的value============"); Collection<String> values = map.values(); Iterator<String> iterator1 = values.iterator(); while (iterator1.hasNext()) { System.out.println(iterator1.next()); } System.out.println("=======JDK8的迭代方式============="); map.forEach((key, value) -> { System.out.println(key ":" value); }); System.out.println("=======entrySet比keySet更高效============="); Set<Map.Entry<String, String>> entries = map.entrySet(); Iterator<Map.Entry<String, String>> iterator2 = entries.iterator(); while (iterator2.hasNext()) { System.out.println(iterator2.next()); } } 結果: ========通過key獲取value============ 101:張三 102:李四 103:王五 ========獲取所有的value============ 張三 李四 王五 =======JDK8的迭代方式============= 101:張三 102:李四 103:王五 =======entrySet比keySet更高效============= 101=張三 102=李四 103=王五來源:https://www./content-4-856201.html |
|