java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java中list和set

Java中的各种list有什么区别及list和set区别详析

作者:y = xⁿ

List是Java集合框架中使用频率比较高的一个接口,它的特点是存储的数据是有序的并且数据是可以重复的,这篇文章主要介绍了Java中各种list有什么区别及list和set区别的相关资料,需要的朋友可以参考下

Java 中 List 的几种实现

List 是 有序、可重复 的集合接口
常见实现:ArrayList、LinkedList、Vector、Stack、CopyOnWriteArrayList

ArrayList

底层结构

新容量 = 旧容量 + 旧容量 / 2 (1.5 倍)

时间复杂度

操作复杂度说明
随机访问 get(i)O(1)数组下标
尾部 addO(1) 均摊扩容时 O(n)
中间插入/删除O(n)元素整体移动

线程安全

解决方案:Collections.synchronizedList;CopyOnWriteArrayList

LinkedList

底层结构

时间复杂度

操作复杂度说明
get(i)O(n)要遍历
头/尾插入删除O(1)指针操作
中间插入O(n)找位置

Vector

底层结构

-动态数组(和 ArrayList 类似)

关键区别

问题

Stack

继承关系

Stack extends Vector

特点

CopyOnWriteArrayList(并发重点)

底层思想

特点

方面说明
线程安全
读性能非常高
写性能较差(复制数组)
迭代不会抛 ConcurrentModificationException

对比总结

实现底层线程安全适合场景
ArrayList动态数组查询多
LinkedList双向链表头尾操作多
Vector动态数组淘汰
Stack淘汰
CopyOnWriteArrayList数组复制并发读多

面试常见问题

Q1:ArrayList 和 LinkedList 区别?

ArrayList:数组,查询快,插入慢
LinkedList:链表,头尾操作快,随机访问慢

Q2:为什么 ArrayList 不是线程安全?

add / remove 过程中可能发生:
扩容
覆盖
数据丢失

Q3:CopyOnWriteArrayList 为什么读快?

读操作不加锁
始终读的是稳定数组快照

Q4:为什么不推荐 Vector / Stack?

synchronized 粒度太大
性能差
有更好的并发方案

总结

ArrayList 查得快,LinkedList 插得快(头尾),
并发读多用 CopyOnWrite,Vector Stack 已淘汰

一、关于List和Set

List vs Set

对比点ListSet
是否有序✅ 有序(按插入顺序)❌ 大多无序(LinkedHashSet 例外)
是否允许重复✅ 允许❌ 不允许
是否有下标✅ 有(get(i)❌ 没有
常见实现ArrayListLinkedListHashSetLinkedHashSetTreeSet
典型用途保存“有顺序、可重复”的数据保存“去重”的数据

一句话记忆:

List = 有顺序 + 可重复
Set = 去重

二、List

什么是List?

List<Integer> list = new ArrayList<>();
list.add(10);
list.add(10);
list.add(20);

System.out.println(list); // [10, 10, 20]
System.out.println(list.get(1)); // 10

三、Set

什么是Set?

Set<Integer> set = new HashSet<>();
set.add(10);
set.add(10);
set.add(20);

System.out.println(set); // [10, 20]

Set 是怎么判断“重复”的?

靠 hashCode() + equals()

  1. 先算 hashCode
  2. 再用 equals 比较

四、List vs Set 核心区别

List 和 Set 都是 Collection 的子接口,主要区别在于是否允许重复和是否有顺序。List 允许重复元素并且有下标,适合顺序存储;Set 不允许重复元素,主要用于去重。

五、一句话总结

List:顺序 + 重复 + 下标
Set:去重 + 无下标 + 基于 equals/hashCode

到此这篇关于Java中各种list有什么区别及list和set区别详析的文章就介绍到这了,更多相关Java中list和set内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文