java常见集合有什么


在Java中,集合框架是处理一组对象的核心API,位于java.util包下。常用的集合主要分为两大类:
Collection接口的实现类(存储单列数据),Map接口的实现类(存储键值对数据)

Collection 接口的常用实现类

Collection 是所有单列集合的根接口,其子接口包括 List、Set、Queue 等。

List(有序、可重复)

特点:元素按插入顺序存储,允许重复,可通过索引访问。

常用实现类:

ArrayList

基于动态数组实现,查询快(O(1)),增删慢(O(n))。

适用于频繁读取、较少修改的场景。

    List<String> list = new ArrayList<>();
list.add("A"); list.add("B");

LinkedList

基于双向链表实现,增删快(O(1)),查询慢(O(n))。

适用于频繁插入、删除的场景(如队列、栈)。

    List<String> list = new LinkedList<>();
list.add("A"); list.add("B");

Set(无序、不可重复)

特点:元素唯一,不保证顺序(部分实现类可排序)。

常用实现类:

HashSet

基于HashMap实现,无序,依赖hashCode()和equals()去重。

适用于需要快速查找、去重的场景。

    Set<String> set = new HashSet<>();
set.add("A"); set.add("B");

LinkedHashSet

继承HashSet,维护插入顺序(基于链表+哈希表)。

适用于需要保留插入顺序的场景。

    Set<String> set = new LinkedHashSet<>();
set.add("A"); set.add("B");

TreeSet

基于红黑树实现,元素自动排序(自然排序或自定义Comparator)。

适用于需要有序数据的场景。

    Set<String> set = new TreeSet<>();
set.add("B"); set.add("A"); // 输出时按字母顺序

Queue(队列,FIFO)

特点:先进先出(FIFO),部分实现支持优先级。

常用实现类:

LinkedList(实现了Queue接口)

可作为普通队列或双端队列(Deque)。

    Queue<String> queue = new LinkedList<>();
queue.offer("A"); // 入队
queue.poll();     // 出队

PriorityQueue

基于堆实现,元素按优先级排序(默认最小堆)。

适用于任务调度、优先级队列。

    Queue<Integer> pq = new PriorityQueue<>();
pq.offer(3); pq.offer(1); // 出队顺序:1, 3

ArrayDeque(高效的双端队列,比LinkedList性能更好)

    Deque<String> deque = new ArrayDeque<>();
deque.addFirst("A"); deque.addLast("B");

Map 接口的常用实现类

Map 存储键值对(key-value),key唯一,value可重复。

HashMap

特点:基于哈希表实现,无序,key和value可为null。

适用场景:高频读写,需要快速查找。

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

map.put(“A”, 1); map.put(“B”, 2);

LinkedHashMap

特点:继承HashMap,维护插入顺序或访问顺序(LRU缓存常用)。

适用场景:需要保留插入顺序或实现LRU缓存。

Map<String, Integer> map = new LinkedHashMap<>();

map.put(“A”, 1); map.put(“B”, 2);

TreeMap

特点:基于红黑树实现,key自动排序(自然排序或自定义Comparator)。

适用场景:需要有序数据的场景(如按年龄排序的用户列表)。

Map<String, Integer> map = new TreeMap<>();
map.put("B", 2); map.put("A", 1); // 输出时按key排序

Hashtable

特点:线程安全(所有方法synchronized),key和value不能为null。

适用场景:遗留代码或需要简单线程安全的场景(现代Java更推荐ConcurrentHashMap)。

ConcurrentHashMap

特点:线程安全,高并发性能优于Hashtable(分段锁或CAS优化)。

适用场景:高并发环境下的键值存储。

Map<String, Integer> map = new ConcurrentHashMap<>();
map.put("A", 1);

其他常用集合工具类

Collections:提供静态方法操作集合(如排序、同步包装)。

List<String> list = new ArrayList<>();
Collections.sort(list); // 排序
List<String> syncList = Collections.synchronizedList(list); // 同步包装

Arrays:操作数组的工具类(如asList将数组转List)。

List<String> list = Arrays.asList("A", "B"); // 注意:返回的是固定大小的List

总结对比表

分类接口/类特点适用场景
ListArrayList动态数组,查询快频繁读取,较少修改
LinkedList双向链表,增删快频繁插入、删除(如队列、栈)
SetHashSet哈希表实现,无序快速去重、查找
LinkedHashSet维护插入顺序需保留插入顺序
TreeSet红黑树实现,自动排序需要有序数据
QueueLinkedList双端队列普通队列或栈操作
PriorityQueue堆实现,优先级排序任务调度、优先级队列
MapHashMap哈希表,无序高频读写
LinkedHashMap维护插入/访问顺序LRU缓存、保留顺序
TreeMap红黑树,自动排序需要有序键值对
ConcurrentHashMap高并发线程安全多线程环境
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值