国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

16 個 Java 集合框架實戰案例,從入門到精通全搞定

開發
今天這篇文章,我把 Java 集合框架中最常用的 16 個實戰案例一次性講透,從基礎用法到高級技巧,每個案例都配上真實業務場景的代碼示例,看完讓你對集合的使用豁然開朗,開發效率直接翻倍!

還在為 Java 集合框架頭疼嗎?ArrayList 和 LinkedList 到底該用哪個?HashMap 為什么會出現死循環?集合遍歷總拋ConcurrentModificationException 怎么破?別慌!今天這篇文章,我把 Java 集合框架中最常用的 16 個實戰案例一次性講透,從基礎用法到高級技巧,每個案例都配上真實業務場景的代碼示例,看完讓你對集合的使用豁然開朗,開發效率直接翻倍!

一、List 集合實戰:有序集合的核心用法

1. ArrayList 基本操作:增刪改查

ArrayList 是最常用的 List 實現類,底層是動態數組,查詢快、增刪慢,適合讀多寫少的場景。

public class ArrayListDemo {


   public static void main(String[] args) {


       // 創建 ArrayList 并添加元素

       List<String> fruits = new ArrayList<>();


       fruits.add("蘋果");


       fruits.add("香蕉");


       fruits.add("橙子");


       // 訪問元素

       System.out.println("第二個水果:" + fruits.get(1)); // 輸出:香蕉

       // 修改元素

       fruits.set(2, "葡萄");


       // 刪除元素

       fruits.remove(0);


       // 遍歷元素

       for (String fruit : fruits) {


           System.out.println(fruit);


       }


       // 輸出:

       // 香蕉

       // 葡萄

   }


}

使用場景:商品列表展示、用戶訂單記錄等需要頻繁查詢的場景。

2. LinkedList 實戰:鏈表的高效增刪

LinkedList 底層是雙向鏈表,增刪快、查詢慢,適合頻繁插入刪除的場景。

public class LinkedListDemo {


   public static void main(String[] args) {


       LinkedList<String> queue = new LinkedList<>();


       // 模擬隊列:尾部添加,頭部移除

       queue.addLast("任務1");


       queue.addLast("任務2");


       queue.addLast("任務3");


       while (!queue.isEmpty()) {


           String task = queue.removeFirst();


           System.out.println("處理任務:" + task);


       }


       // 輸出:

       // 處理任務:任務1

       // 處理任務:任務2

       // 處理任務:任務3

   }


}

使用場景:消息隊列、棧、鏈表結構的業務場景(如最近瀏覽記錄)。

3. List 排序:自定義排序規則

對 List 中的元素進行排序,支持自然排序和自定義排序。

public class ListSortDemo {


   public static void main(String[] args) {


       List<User> users = new ArrayList<>();


       users.add(new User("張三", 25));


       users.add(new User("李四", 20));


       users.add(new User("王五", 30));


       // 按年齡升序排序(自定義比較器)

       users.sort(Comparator.comparingInt(User::getAge));


       // 遍歷排序后的結果

       users.forEach(user -> System.out.println(user.getName() + ":" + user.getAge()));


       // 輸出:

       // 李四:20

       // 張三:25

       // 王五:30

       // 按年齡降序排序

       users.sort((u1, u2) -> Integer.compare(u2.getAge(), u1.getAge()));


   }


   static class User {


       private String name;


       private int age;


       // 構造方法、getter、setter省略

   }


}

4. List 去重:多種去重方式對比

在開發中經常需要對 List 進行去重,不同方式效率不同。

public class ListDeduplicationDemo {


   public static void main(String[] args) {


       List<String> list = Arrays.asList("a", "b", "a", "c", "b");


       // 方式1:通過 HashSet 去重(無序)

       List<String> distinct1 = new ArrayList<>(new HashSet<>(list));


       // 方式2:通過 LinkedHashSet 去重(保持順序)

       List<String> distinct2 = new ArrayList<>(new LinkedHashSet<>(list));


       // 方式3:Java 8 Stream 去重(保持順序)

       List<String> distinct3 = list.stream().distinct().collect(Collectors.toList());


       System.out.println(distinct2); // 輸出:[a, b, c]

   }


}

推薦:需要保持順序用 LinkedHashSet 或 Stream.distinct (),無需保持順序用 HashSet。

二、Set 集合實戰:無序不重復集合

5. HashSet 基本用法:快速去重

HashSet 基于哈希表實現,元素無序且唯一,查詢效率高。

public class HashSetDemo {


   public static void main(String[] args) {


       Set<String> tags = new HashSet<>();


       tags.add("Java");


       tags.add("Python");


       tags.add("Java"); // 重復元素,添加失敗

       System.out.println(tags.size()); // 輸出:2

       // 遍歷(無序)

       for (String tag : tags) {


           System.out.println(tag);


       }


   }


}

使用場景:標簽去重、用戶 ID 去重、過濾重復數據等。

6. TreeSet 排序:自然排序與定制排序

TreeSet 可以對元素進行排序,默認是自然排序,也可以自定義排序規則。

public class TreeSetDemo {


   public static void main(String[] args) {


       // 自然排序(String 實現了 Comparable 接口)

       Set<String> treeSet1 = new TreeSet<>();


       treeSet1.add("c");


       treeSet1.add("a");


       treeSet1.add("b");


       System.out.println(treeSet1); // 輸出:[a, b, c]

       // 自定義排序(按字符串長度)

       Set<String> treeSet2 = new TreeSet<>(Comparator.comparingInt(String::length));


       treeSet2.add("apple");


       treeSet2.add("banana");


       treeSet2.add("pear");


       System.out.println(treeSet2); // 輸出:[pear, apple, banana]

   }


}

7. 利用 Set 檢查重復元素

在批量插入數據時,先檢查是否有重復元素,避免插入重復數據。

public class CheckDuplicateDemo {


   public static void main(String[] args) {


       List<String> userIds = Arrays.asList("1001", "1002", "1001", "1003");


       Set<String> existingIds = new HashSet<>();


       List<String> duplicates = new ArrayList<>();


       for (String id : userIds) {


           if (!existingIds.add(id)) { // add失敗說明已存在

               duplicates.add(id);


           }


       }


       System.out.println("重復的用戶ID:" + duplicates); // 輸出:[1001]

   }


}

三、Map 集合實戰:鍵值對存儲的利器

8. HashMap 基本操作:最常用的鍵值對集合

HashMap 是最常用的 Map 實現類,基于哈希表,查詢效率高,允許 key 和 value 為 null。

public class HashMapDemo {


   public static void main(String[] args) {


       Map<String, Integer> scoreMap = new HashMap<>();


       // 添加元素

       scoreMap.put("張三", 90);


       scoreMap.put("李四", 85);


       scoreMap.put("王五", 95);


       // 獲取元素

       int score = scoreMap.get("張三"); // 90

       // 遍歷key

       for (String name : scoreMap.keySet()) {


           System.out.println(name + ":" + scoreMap.get(name));


       }


       // 遍歷key-value

       for (Map.Entry<String, Integer> entry : scoreMap.entrySet()) {


           System.out.println(entry.getKey() + ":" + entry.getValue());


       }


       // Java 8 forEach

       scoreMap.forEach((name, s) -> System.out.println(name + ":" + s));


   }


}

使用場景:存儲鍵值對數據,如用戶信息(key 為用戶 ID,value 為用戶對象)、配置參數等。

9. HashMap 進階:處理 null 鍵值與遍歷方式對比

HashMap 允許 key 和 value 為 null,但要注意處理方式。

public class HashMapAdvancedDemo {


   public static void main(String[] args) {


       Map<String, String> map = new HashMap<>();


       map.put(null, "null key");


       map.put("key1", null);


       System.out.println(map.get(null)); // 輸出:null key

       System.out.println(map.get("key1")); // 輸出:null

       // 注意:get方法返回null可能是key不存在,也可能是value為null

       // 判斷key是否存在

       System.out.println(map.containsKey("key1")); // 輸出:true

       // 遍歷方式效率對比:entrySet比keySet高效(減少一次get操作)

       // 推薦使用entrySet或forEach

   }


}

10. LinkedHashMap:保持插入順序的 Map

LinkedHashMap 繼承自 HashMap,能保持元素的插入順序或訪問順序。

public class LinkedHashMapDemo {


   public static void main(String[] args) {


       // 保持插入順序

       Map<String, String> linkedHashMap = new LinkedHashMap<>();


       linkedHashMap.put("name", "張三");


       linkedHashMap.put("age", "25");


       linkedHashMap.put("gender", "男");


       // 遍歷順序與插入順序一致

       linkedHashMap.forEach((k, v) -> System.out.println(k + ":" + v));


       // 按訪問順序排序(最近訪問的放在最后)

       Map<String, String> accessOrderMap = new LinkedHashMap<>(16, 0.75f, true);


       accessOrderMap.put("a", "a");


       accessOrderMap.put("b", "b");


       accessOrderMap.get("a"); // 訪問a

       accessOrderMap.put("c", "c");


       // 遍歷順序:b, a, c(a被訪問過,放在c前面)

   }


}

使用場景:實現 LRU 緩存(最近最少使用淘汰策略)。

11. 統計元素出現次數:Map 經典用法

統計一個列表中每個元素出現的次數,是 Map 的典型應用。

public class CountElementsDemo {


   public static void main(String[] args) {


       List<String> words = Arrays.asList("apple", "banana", "apple", "orange", "banana", "apple");


       Map<String, Integer> countMap = new HashMap<>();


       // 統計次數

       for (String word : words) {


           countMap.put(word, countMap.getOrDefault(word, 0) + 1);


       }


       // Java 8 Stream方式

       Map<String, Long> countMap2 = words.stream()


               .collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));


       System.out.println(countMap); // 輸出:{apple=3, banana=2, orange=1}

   }


}

三、集合進階:工具類與高級操作

12. Collections 工具類:集合操作的好幫手

Collections 提供了大量靜態方法,用于操作集合,如排序、查找、同步化等。

public class CollectionsDemo {


   public static void main(String[] args) {


       List<String> list = new ArrayList<>(Arrays.asList("b", "a", "c"));


       // 排序

       Collections.sort(list);


       System.out.println(list); // 輸出:[a, b, c]

       // 二分查找(需先排序)

       int index = Collections.binarySearch(list, "b"); // 1

       // 反轉

       Collections.reverse(list);


       System.out.println(list); // 輸出:[c, b, a]

       // 創建不可修改的集合

       List<String> unmodifiableList = Collections.unmodifiableList(list);


       // unmodifiableList.add("d"); // 拋UnsupportedOperationException

       // 創建同步集合(線程安全)

       List<String> synchronizedList = Collections.synchronizedList(new ArrayList<>());


   }


}

13. 集合與數組轉換:相互轉換的技巧

集合和數組之間經常需要轉換,注意轉換后的可變性。

public class CollectionArrayConversionDemo {


   public static void main(String[] args) {


       // 集合轉數組

       List<String> list = Arrays.asList("a", "b", "c");


       String[] array1 = list.toArray(new String[0]); // 推薦方式

       // 數組轉集合

       String[] array = {"x", "y", "z"};


       List<String> list1 = Arrays.asList(array); // 返回的是固定大小的列表,不能增刪

       // 轉為可修改的ArrayList

       List<String> list2 = new ArrayList<>(Arrays.asList(array));


       list2.add("w"); // 可以正常增刪

   }


}

注意:Arrays.asList () 返回的列表是固定大小的,不能進行 add/remove 操作。

14. 集合遍歷與迭代器:避免 ConcurrentModificationException

在遍歷集合時修改集合(增刪元素)可能會拋出 ConcurrentModificationException。

public class IteratorDemo {


   public static void main(String[] args) {


       List<String> list = new ArrayList<>(Arrays.asList("a", "b", "c"));


       // 錯誤方式:foreach循環中刪除元素

       // for (String s : list) {

       //     if ("a".equals(s)) {

       //         list.remove(s); // 拋ConcurrentModificationException

       //     }

       // }

       // 正確方式1:使用迭代器

       Iterator<String> iterator = list.iterator();


       while (iterator.hasNext()) {


           String s = iterator.next();


           if ("a".equals(s)) {


               iterator.remove(); // 迭代器的remove方法

           }


       }


       // 正確方式2:Java 8 removeIf(推薦)

       list.removeIf("b"::equals);


       System.out.println(list); // 輸出:[c]

   }


}

15. 集合過濾與轉換:Stream API 的妙用

Java 8 的 Stream API 為集合操作提供了強大的支持,如過濾、映射、聚合等。

public class StreamCollectionDemo {


   public static void main(String[] args) {


       List<User> users = Arrays.asList(


               new User("張三", 20, "男"),


               new User("李四", 25, "女"),


               new User("王五", 30, "男")


       );


       // 過濾:年齡大于22的男性用戶

       List<User> filtered = users.stream()


               .filter(user -> user.getAge() > 22 && "男".equals(user.getGender()))


               .collect(Collectors.toList());


       // 轉換:提取用戶名列表

       List<String> names = users.stream()


               .map(User::getName)


               .collect(Collectors.toList());


       // 聚合:計算平均年齡

       double avgAge = users.stream()


               .mapToInt(User::getAge)


               .average()


               .orElse(0);


       System.out.println(avgAge); // 輸出:25.0

   }


}

16. 集合初始化容量:提高性能的小技巧

初始化集合時指定合適的容量,可以減少擴容次數,提高性能。

public class CollectionInitialCapacityDemo {


   public static void main(String[] args) {


       // 已知大概有1000個元素,指定初始容量1000(HashMap負載因子0.75,1000/0.75≈1333)

       Map<String, Object> map = new HashMap<>(1333);


       // ArrayList默認初始容量10,每次擴容為原來的1.5倍

       // 已知元素量時直接指定,減少擴容

       List<String> list = new ArrayList<>(1000);


   }


}

原理:HashMap 擴容時需要重新計算哈希并遷移元素,ArrayList 擴容需要復制數組,指定初始容量可減少這些操作。

責任編輯:趙寧寧 來源: 編程江湖
相關推薦

2022-06-10 08:17:52

HashMap鏈表紅黑樹

2010-02-06 15:31:18

ibmdwAndroid

2009-07-22 14:55:16

ibmdwAndroid

2017-05-09 08:48:44

機器學習

2016-12-08 22:39:40

Android

2012-02-29 00:49:06

Linux學習

2025-02-24 10:07:10

2025-10-31 00:17:39

2024-11-25 18:37:09

2024-02-26 08:52:20

Python傳遞函數參數參數傳遞類型

2022-09-02 15:11:18

開發工具

2010-11-08 10:20:18

2025-07-29 02:00:00

2025-10-09 01:33:00

2025-05-12 10:15:00

Linuxdiff系統

2025-03-11 00:00:00

2009-07-03 18:49:00

網吧綜合布線

2023-10-13 08:23:05

2024-06-07 08:51:50

OpenPyXLPythonExcel文件

2009-03-19 13:36:53

SSH安全通道遠程
點贊
收藏

51CTO技術棧公眾號

精品一二三四在线| 免费在线观看91| 亚洲小说春色综合另类电影| 欧美精品在线看| 天堂va在线高清一区| 国产91ⅴ在线精品免费观看| 神马电影久久| 97碰碰视频| 日韩vs国产vs欧美| www.日本少妇| 亚洲蜜桃精久久久久久久| 在线免费看污| 日韩欧美在线观看一区二区三区| a级片在线免费观看| 丝袜亚洲另类欧美重口| 三级精品视频| 久中文字幕一区| av不卡免费在线观看| 3dmax动漫人物在线看| 欧美一级在线视频| 成人亚洲精品| 91亚洲精品视频| 国产老肥熟一区二区三区| 日本黄大片一区二区三区| 色女孩综合影院| 中文不卡1区2区3区| 国产91成人在在线播放| 欧美午夜在线视频| 欧美日韩性生活片| 日韩欧美国产免费播放| 美女视频在线免费| 国产精品激情av在线播放| 秋霞午夜av一区二区三区| www.这里只有精品| 日韩欧美123| 欧美在线导航| 一区在线电影| 亚洲一级不卡视频| 色在线视频观看| 国产欧美日韩91| 成人午夜激情视频| 巨骚激情综合| 欧美精品国产精品日韩精品| 亚洲毛片网站| free性欧美1819hd| 亚洲美女精品久久| 日韩精品一区二区三区免费观看| 99热都是精品| 欧美影院一区二区三区| 久久亚洲人体| 欧美三级网色| 亚洲综合色噜噜狠狠| 99精品国自产在线| 欧美精品一区在线| 亚洲成人一区二区| 欧美电影院免费观看| 亚洲欧美日韩国产成人综合一二三区 | 91国内精品久久| 蜜臀av在线播放一区二区三区| 全部孕妇毛片丰满孕妇孕| 在线播放国产一区二区三区| 极品裸体白嫩激情啪啪国产精品| 男女啪啪网站视频| 精品一区电影国产| 99精品免费网| 草莓污污视频在线观看| 九九精品视频在线观看| 久久精品国产亚洲高清剧情介绍 | 国产视频一区三区| 丝袜美女写真福利视频| 日韩中文在线中文网在线观看| 欧美成熟视频| gogo高清免费视频| 久久久av免费| 韩国理伦片一区二区三区在线播放| 青青国产在线| 日本最新高清不卡中文字幕| 99国产精品国产精品久久| 99热99re6国产在线播放| av一区二区在线看| 亚洲国产欧美在线| 色天下一区二区三区| 国产精品无码av无码| 正在播放亚洲1区| 精品一区二区三区在线播放 | 成人黄18免费网站| 欧美成人亚洲成人| 福利视频网站一区二区三区| 成人福利电影| 国产精品99久久久久久大便| 日韩亚洲欧美综合| 天堂影院一区二区| 免费电影网站在线视频观看福利| 开心色怡人综合网站| 91精品在线观看入口| 国产精品日韩久久久| 在线视频婷婷| 久久久久国产精品视频| 欧美精品久久久久久久久老牛影院| 欧美网站在线| www.亚洲资源| 久久久久久久免费| 欧美精品一区二区三区视频| 精品一区二区三区香蕉蜜桃| 在线免费av资源| 亚洲熟妇无码一区二区三区导航| 这里只有精品视频| 国产亚洲精品久| 国产精品男女| 国产青青视频| 国产欧美婷婷中文| 精品欧美激情精品一区| 韩国av一区| 国产秀色在线www免费观看| 欧美精品一区三区在线观看| 亚洲大胆人体av| 成a人片国产精品| 国产精品xxxav免费视频| 一级免费视频| 国产精品白丝jk白祙| 亚洲丁香婷深爱综合| 成人av在线资源网站| 都市激情亚洲| 最新天堂资源在线资源| 超碰97网站| 亚洲精品久久久久久久久久久| 成人av一区二区三区| 超碰cao国产精品一区二区| 天堂男人av| 精品视频第一区| 亚洲精品一区二区在线| 久久久美女艺术照精彩视频福利播放| 偷窥自拍亚洲色图精选| 成人一区二区不卡免费| 欧美精品一区二区性色a+v| 欧美黑人性猛交| 日本韩国欧美三级| 国产精品一区二区男女羞羞无遮挡| 久久精品九色| 视频在线91| 中文字幕中文字幕在线中心一区| 久久国产精品久久久久久| 午夜精品一区在线观看| 免费视频最近日韩| 91精品入口| 粉嫩一区二区三区国产精品| 国产aaa免费视频| 国产免费亚洲高清| 亚洲精品网址在线观看| 亚洲人精品午夜| 日韩黄色小视频| 超碰97久久国产精品牛牛| 可以在线观看的黄色| 日本午夜激情视频| 91日韩久久| 日韩亚洲在线观看| 在线视频一区二区三区| 99久久久免费精品国产一区二区| 国产精品久久久久9999赢消| 日韩色淫视频| 第九色区av在线| 丰满少妇被猛烈进入高清播放| 国产精品一区在线播放| 久久久之久亚州精品露出| 日韩欧美资源站| 亚洲精品成人精品456| 国产一区二区不卡老阿姨| 欧美大黑bbbbbbbbb在线| 不卡一二三区| 黄色在线观看网| www.日本一区| 国产成人精品免费看在线播放 | 麻豆国产精品一区二区三区 | 精品国产伦理网| 亚洲国产一区二区三区青草影视| 狠狠色丁香九九婷婷综合五月| 日韩久久久久| 亚洲欧洲日韩精品在线| 午夜成年人在线免费视频| fc2人成共享视频在线观看| 国产av人人夜夜澡人人爽麻豆| 国产精品久久九九| 奇米四色中文综合久久| 一区二区在线免费视频| 欧美无乱码久久久免费午夜一区| 国产精品网曝门| 国产传媒久久文化传媒| 亚洲在线一区| 91精品国产自产在线观看永久∴| 亚洲精品午夜| 日产精品一区| 99自拍视频在线观看| 深夜福利在线观看直播| 91欧美视频在线| 欧美一级欧美一级| 亚洲欧洲中文| 麻豆av一区二区三区久久| 51精品国产人成在线观看| 国产精品av在线| 98视频在线噜噜噜国产|