Java List 集合介绍

一、List 集合概述

List 是 Java 集合框架中 有序、可重复 的接口,继承自 Collection,允许通过索引访问元素。其核心实现类包括 ArrayListLinkedListVector,各有不同的底层结构和适用场景。

二、核心实现类详解

  1. ArrayList
  • 底层结构 :动态数组(Object[]),支持自动扩容。

  • 核心特性

    • 访问效率 :按索引访问快(时间复杂度 O(1)),适合随机访问。
    • 增删效率 :尾部增删快(O(1)),中间增删慢(需移动元素,O(n))。
    • 线程安全 :非线程安全,多线程环境需手动同步(如 Collections.synchronizedList())。
    • 内存占用:较低(仅存储数据,无额外指针开销)。
  • 常用方法

    复制代码
    ArrayList<String> list = new ArrayList<>();
    list.add("元素"); // 尾部添加
    list.add(1, "插入元素"); // 指定索引插入
    list.set(0, "替换元素"); // 替换指定索引元素
    list.get(0); // 获取索引元素
    list.remove(0); // 按索引删除
    list.remove("元素"); // 按值删除
    list.contains("元素"); // 判断是否包含
    list.size(); // 获取元素数量
    list.clear(); // 清空集合
  • 遍历方式

    • 普通 for 循环(适合随机访问);
    • 增强 for 循环(简洁);
    • forEach 方法(Lambda 表达式)。
  • 适用场景:大量读操作、随机访问频繁,元素增删较少的场景(如数据展示、查询结果存储)。

  1. LinkedList
  • 底层结构:双向链表,每个节点存储数据及前后节点引用。

  • 核心特性

    • 访问效率 :按索引访问慢(需遍历链表,O(n)),不适合随机访问。
    • 增删效率 :首尾增删快(O(1)),中间增删只需修改指针(O(n),主要耗时在遍历定位)。
    • 线程安全:非线程安全。
    • 内存占用:较高(需额外存储前后节点指针)。
  • 特有方法 (实现 Deque 接口,支持队列 / 栈操作):

    复制代码
    LinkedList<String> list = new LinkedList<>();
    list.addFirst("首元素"); // 头部添加
    list.addLast("尾元素"); // 尾部添加
    list.getFirst(); // 获取首元素(空表抛异常)
    list.getLast(); // 获取尾元素(空表抛异常)
    list.peekFirst(); // 安全获取首元素(空表返回 null)
    list.peekLast(); // 安全获取尾元素(空表返回 null)
    list.removeFirst(); // 删除首元素(空表抛异常)
    list.removeLast(); // 删除尾元素(空表抛异常)
    list.pollFirst(); // 安全删除首元素(空表返回 null)
  • 遍历方式

    • 增强 for 循环(推荐);
    • 迭代器 Iterator(支持边遍历边删除,避免并发异常);
    • 逆序迭代器 descendingIterator()(从尾到头遍历)。
  • 适用场景:频繁在首尾或中间位置增删元素的场景(如队列、栈、链表结构模拟)。

  1. Vector(不推荐新项目使用)
  • 底层结构 :动态数组(Object[]),早期线程安全实现。

  • 核心特性

    • 线程安全 :所有方法用 synchronized 修饰,保证多线程安全,但性能较低。
    • 扩容机制:默认初始容量 10,满容后扩容为原容量的 2 倍(ArrayList 为 1.5 倍)。
    • 功能:与 ArrayList 类似,但方法加锁导致单线程性能差。
  • 常用方法 :与 ArrayList 基本一致,额外支持 Enumeration 遍历(遗留接口)。

  • 适用场景 :需线程安全的多线程场景(现多被 ArrayList + Collections.synchronizedList()CopyOnWriteArrayList 替代)。

三、三大实现类对比表

特性 ArrayList LinkedList Vector
底层结构 动态数组 双向链表 动态数组
随机访问效率 快(O(1) 慢(O(n) 快(O(1)
中间增删效率 慢(O(n) 较快(O(n),定位耗时) 慢(O(n)
首尾增删效率 快(O(1) 快(O(1) 快(O(1)
线程安全 是(方法加锁)
内存占用 高(节点指针)
适用场景 大量读操作、随机访问 频繁增删(首尾 / 中间) 多线程安全需求(少用)

四、使用建议

  1. 单线程场景

    • 以查询为主、少量增删 → 优先 ArrayList(性能最优)。
    • 频繁增删(尤其是中间位置) → 选择 LinkedList
  2. 多线程场景

    • 需线程安全 → 用 Collections.synchronizedList(new ArrayList<>())CopyOnWriteArrayList(并发包,读多写少时高效),避免使用 Vector(性能差)。
  3. 遍历注意

    • ArrayList 适合普通 for 循环(索引访问快);
    • LinkedList 适合增强 for 或迭代器(避免索引遍历的性能损耗);
    • 遍历时删除元素需用 Iterator.remove(),避免 ConcurrentModificationException
相关推荐
Dfreedom.2 小时前
Windows、虚拟机、开发板组网通信原理及调试通联步骤
人工智能·windows·部署·边缘计算·开发板·模型加速
三无推导7 小时前
ComfyUI 安装部署教程:Windows 下快速搭建可视化 AI 绘图工作流,零基础也能跑通
人工智能·pytorch·windows·stable diffusion·aigc·ai绘画·持续部署
nnsix9 小时前
PS【PhotoShop】实现拷贝到Windows粘贴板上
windows
сокол9 小时前
【网安-Web渗透测试-免杀系列】内存免杀(无文件落地)
windows·网络安全
玖釉-10 小时前
二叉树基础详解:TreeNode、buildTree、deleteTree 与 printTree 的实现原理(C++)
c++·windows·算法
心之所向,自强不息10 小时前
# Unity MCP + Codex CLI 完整教程(Windows)
windows·unity·游戏引擎
特立独行的猫a10 小时前
Fast DDS Monitor Windows x64 从源码编译安装完全教程
windows·monitor·dds·fastdds·fastddsmonitor
慵懒的猫mi11 小时前
deepin 25部署x11vnc+xrdp,实现vnc和mstsc双重访问
linux·windows·开源软件·deepin
神仙别闹11 小时前
基于C语言 实现 Windows PE 文件解析
c语言·windows·microsoft
kebeiovo11 小时前
Codex在Windows安装配置指南
windows