Java中ArrayList和LinkedList有什么区别举例详解

2025-02-22 05:50

本文主要是介绍Java中ArrayList和LinkedList有什么区别举例详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影...

一、底层数据结构

特性ArrayListLinkedList
实现方式基于动态数组基于双向链表
内存布局连续内存块,支持快速随机访问离散节点,每个节点包含数据及前后指针
默认初始容量10(扩容时增长 50%)无预分配容量,动态添加节点

二、核心操作性能对比

// ArrayList的随机访问示例
ArrayList<Integer> arrayList = new ArrayList<>();
arrayList.add(1);
int val1 = arrayList.get(0);  // O(1)

// LinkedList的顺序访问示例
LinkedList<Integer> linkedList = new LinkedList<>();
linkedList.add(1);
int val2 = linkedList.get(0);  // O(n)
操作ArrayList 时间复杂度LinkedList 时间复杂度
随机访问(get/set)O(1)O(n)
头部插入/删除O(n)(需移动元素)O(1)
尾部插入/删除分摊 O(1)(无扩容时 O(1))O(1)
中间插入/删除O(n)O(n)(需遍历到目标位置)

三、内存与 GC 影响

维度ArrayListLinkedList
内存占用仅存储元素 + 数组头(内存紧凑)每个节点额外存储两个指针(对象头 + 前后引用)
GC 压力整体回收高效(单个数组对象)频繁增删产生大量小对象,增加 GC 负担
缓存局部性高(连续内存,CPU 预加载命中率高)低(节点分散,缓存未命中率高)

四、扩容机制

  • ArrayList 扩容流程

    // 扩容核心逻辑(JDK17)
    int newCapacity = oldCapacity + (oldCapacity >> 1); // 1.5倍扩容
    elementData = Arrays.copyOf(elementData, newCapacity);
    
    • 代价:数据复制导致 O(n) 时间复杂度
    • 优化建议:初始化时预估容量(new ArrayList<>(initialCapacity)
  • LinkedList 无扩容:动态添加节点,但每个节点额外占用 24 字节(64 位 JVM)

五、线程安全与并发方案

方案ArrayListLinkedLisjst
默认线程安全
同步包装类Collections.synchronizedList()Collections.synchronizedList()
高并发替代方案CopyOnWr编程iteArrayListConcurrentLinkedDeque

六、工程实践场景

1. 电商商品列表展示

  • 选择 ArrayList

    • 高频读取商品信息(随机访问)
    • 批量更新时通过尾插法优化(addAll()
    List<Product> products = new ArraChina编程yList<>(10000); // 预分配容量
    

2. 实时消息队列

  • 选择 LinkedList

    • 高频头尾操作(addFirst()/removeLast()
    • 使用迭代器避免随机访问:
    LinkedList<Message> queue = new LinkedList<>();
    // 生产者
    queue.offer(new Message());
    // 消费者(高效遍历)
    Iterator<Message> it = queue.iterator();
    while(it.hasNext()) process(it.next());
    

3. 多线程日志处理器

  • 选择 CopyOnWriteArrayList

    • 写操作极少(日志初始化配置)
    • 高频遍历读取日志规则
    CopyOnWriteArrayList<LogRule&gandroidt; rules = new CopyOnWriteArrayList<>();
    // 写操作(仅在配置更新时触发)
    rules.add(new LogRule());
    // 读操作(无锁并发)
    rules.forEach(LogService::applyRule);
    

七、性能对比测试数据

测试环境:JDK17,10 万次操作,i7-11800H

测试场景ArrayList 耗时LinkedList 耗时差异原因
随机访问 1 万次2ms650ms数组 O(1) ZIgiLzTeNvs 链表 O(n) 遍历
尾部插入 1 万次3ms5ms均摊 O(1),链表节点创建开销略高
头部插入 1 万次420ms8ms数组需移动元素,链表直接修改指针
遍历所有元素15ms18ms数组缓存命中率高

八、高级特性对比

特性ArrayListLinkedList
实现接口ListList + Deque
序列化效率高(连续数据,可批量写入)低(需逐个节点处理)
内存池兼容性适合对象池化(数组整体复用)节点分散,池化效果差
批量操作优化System.arraycopy() 高效需要逐个节点操作

九、选型决策树

Java中ArrayList和LinkedList有什么区别举例详解

通过以上对比,开发者可根据具体场景选择最合适的实现:

  • 优先 ArrayList:适用于 90% 的常规场景(读多写少、内存敏感)
  • 慎用 LinkedList:仅在需要频繁头尾操作或实现双端队列时选用
  • 线程安全场景:根据写频率选择 CopyOnWriteArrayList 或同步包装类

结论

  • ArrayList 更适合:如果你的操作主要集中在随机访问和列表末尾的插入删除,且你希望节省内存,ArrayList 是首选。

  • LinkedList 更适合:如果你的操作主要是频繁在列表中间进行插入和删除,而随机访问较少,LinkedList 会表现得更好。

总结 

到此这篇关于Java中ArrayList和LinkedList有什么区别的文章就介绍到这了,更多相关Java中ArrayList和LinkedList区别内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于Java中ArrayList和LinkedList有什么区别举例详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153503

相关文章

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

C#基础之委托详解(Delegate)

《C#基础之委托详解(Delegate)》:本文主要介绍C#基础之委托(Delegate),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 委托定义2. 委托实例化3. 多播委托(Multicast Delegates)4. 委托的用途事件处理回调函数LINQ

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

springboot报错Invalid bound statement (not found)的解决

《springboot报错Invalidboundstatement(notfound)的解决》本文主要介绍了springboot报错Invalidboundstatement(not... 目录一. 问题描述二.解决问题三. 添加配置项 四.其他的解决方案4.1 Mapper 接口与 XML 文件不匹配

GORM中Model和Table的区别及使用

《GORM中Model和Table的区别及使用》Model和Table是两种与数据库表交互的核心方法,但它们的用途和行为存在著差异,本文主要介绍了GORM中Model和Table的区别及使用,具有一... 目录1. Model 的作用与特点1.1 核心用途1.2 行为特点1.3 示例China编程代码2. Tab

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

Python GUI框架中的PyQt详解

《PythonGUI框架中的PyQt详解》PyQt是Python语言中最强大且广泛应用的GUI框架之一,基于Qt库的Python绑定实现,本文将深入解析PyQt的核心模块,并通过代码示例展示其应用场... 目录一、PyQt核心模块概览二、核心模块详解与示例1. QtCore - 核心基础模块2. QtWid

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp