Java中的Collection必知必会

Java中的Collection框架是用于存储、管理和操作对象集合的一组接口和类的统称,位于java.util包中。它提供了多种数据结构,使得开发者无需从头实现即可高效处理数据。以下是核心内容:


1. Collection框架的层次结构

  • Collection接口 :所有集合的根接口,定义了基本操作(添加、删除、遍历等)。
    • 子接口
      • List :有序、允许重复(如 ArrayList, LinkedList)。
      • Set :无序、不允许重复(如 HashSet, TreeSet)。
      • Queue :队列结构,支持先进先出(FIFO)或优先级排序(如 PriorityQueue)。
    • Map接口 :独立于Collection接口,存储键值对(如 HashMap, TreeMap)。

2. 核心接口与实现类

List(有序可重复)

  • ArrayList:基于动态数组,查询快(O(1)),增删慢(需移动元素)。
  • LinkedList :基于双向链表,增删快(O(1)),查询慢(O(n)),同时实现了Deque接口。
  • Vector :线程安全但性能差,通常用Collections.synchronizedList()替代。

Set(无序不可重复)

  • HashSet:基于哈希表,快速查找(O(1)),无序。
  • LinkedHashSet :维护插入顺序的HashSet
  • TreeSet :基于红黑树,元素按自然顺序或Comparator排序(O(log n))。

Queue(队列)

  • LinkedList :可作普通队列或双端队列(Deque)。
  • PriorityQueue:元素按优先级排序(小顶堆)。

Map(键值对)

  • HashMap :基于哈希表,允许null键值,非线程安全。
  • LinkedHashMap:维护插入顺序或访问顺序(LRU实现)。
  • TreeMap:基于红黑树,按键排序。
  • ConcurrentHashMap :线程安全的高性能替代(优于Hashtable)。

3. 工具类 Collections

提供静态方法操作或返回集合:

  • 排序Collections.sort(list)
  • 同步包装Collections.synchronizedList(list)
  • 不可变集合Collections.unmodifiableList(list)

4. 关键特性

  • 泛型 :确保类型安全,如 List<String> list = new ArrayList<>();
  • 迭代器 Iterator :统一遍历集合,支持hasNext(), next(), remove()
  • 比较器 Comparator :定制排序逻辑,与Comparable接口配合使用。
  • Java 8+ Stream API:链式操作集合(如过滤、映射、归约)。

5. 示例代码

java 复制代码
// List示例
List<String> arrayList = new ArrayList<>();
arrayList.add("Java");
arrayList.add("Python");
System.out.println(arrayList); // [Java, Python]

// Set示例
Set<Integer> hashSet = new HashSet<>();
hashSet.add(1);
hashSet.add(1); // 重复元素无效
System.out.println(hashSet); // [1]

// Map示例
Map<String, Integer> hashMap = new HashMap<>();
hashMap.put("A", 1);
hashMap.put("B", 2);
System.out.println(hashMap.get("A")); // 1

// 使用Stream API过滤
List<String> languages = Arrays.asList("Java", "Python", "C++");
List<String> filtered = languages.stream()
                                .filter(s -> s.startsWith("J"))
                                .collect(Collectors.toList()); // [Java]

6. 线程安全与并发集合

  • 非线程安全类 :如ArrayList, HashMap,性能高但需自行处理同步。
  • 线程安全替代
    • ConcurrentHashMap:分段锁机制,高并发场景优先使用。
    • CopyOnWriteArrayList:写时复制,适合读多写少。
    • 使用Collections.synchronizedXXX()包装非安全集合。

7. 选择集合的建议

  • 随机访问多ArrayList
  • 频繁增删LinkedList
  • 去重HashSet
  • 排序需求TreeSetTreeMap
  • 键值存储HashMap
  • 高并发ConcurrentHashMap

掌握Collection框架能显著提升代码效率和可维护性,建议结合具体场景灵活选择数据结构。

相关推荐
俺不是西瓜太郎´•ﻌ•`14 分钟前
二维差分数组(JAVA)蓝桥杯
java·开发语言·蓝桥杯
cainiao08060519 分钟前
Java大数据可视化在城市空气质量监测与污染溯源中的应用:GIS与实时数据流的技术融合
java·开发语言·信息可视化
2685725921 分钟前
Java 23种设计模式 - 行为型模式11种
java·开发语言·设计模式
编程点滴路40 分钟前
LinkedList源码解析
java·开发语言
花花鱼1 小时前
spring boot lunar 农历的三方库引用,获取日期的农历值
java·前端·spring boot
一切皆有迹可循1 小时前
Spring Boot 基于 Cookie 实现单点登录:原理、实践与优化详解
java·spring boot·后端
喂我花生(๑•̀ㅂ•́)و✧1 小时前
JAVA中ArrayList的解析
java·开发语言·算法
forestsea1 小时前
Java 基础面试题
java·开发语言
从int开始2 小时前
在过滤器中获取body中的json数据并且使得后续的controller层也能获取使用
java·filter
长勺2 小时前
Java云原生到底是啥,有哪些技术
java·开发语言·云原生