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
相关推荐
сокол2 小时前
【网安-Web渗透测试-内网渗透】内网横向移动——IPC连接
服务器·windows·网络安全·系统安全
BUG研究员_2 小时前
Apifox调用本地大模型
windows
无限进步_2 小时前
【C++】从红黑树到 map 和 set:封装设计与迭代器实现
开发语言·数据结构·数据库·c++·windows·github·visual studio
xhbh6662 小时前
Windows网络转发如何配置?netsh命令完整指南
服务器·网络·windows·ip·端口流量转发·路由端口转发·ip隐藏
程序员大辉2 小时前
Rufus中文版(U盘引导盘制作工具)v4.14.2377,PE U盘启动工具,重装系统必备的软件工具
运维·windows
Byron Loong2 小时前
【逆向】PE 文件加载核心流程
windows
轻夏3 小时前
windows的Copilot键改右ctrl以及双击资源管理器空白地方后退到上一级目录
windows·copilot
AI阿阳3 小时前
✅真・喂饭级教程:2026 年 OpenClaw(Clawdbot)新手部署 + 飞书接入步骤流程
人工智能·windows·飞书·openclaw·openclaw 教程·本地 ai 部署
XS0301063 小时前
Java基础 List集合
java·windows·list