Java进阶小妙招:ArrayList和LinkedList的"相爱相杀"

一、核心概念

ArrayList基于动态数组,查询快增删慢;LinkedList基于双向链表,增删快查询慢,俩都是List接口实现类,日常开发高频用。

二、关键语法&代码示例

  1. 初始化与基础操作
java 复制代码
// ArrayList初始化
List<String> arrayList = new ArrayList<>();
arrayList.add("Java");
arrayList.add("进阶");
// 随机访问(优势)
System.out.println(arrayList.get(0)); // 直接通过索引获取,速度快

// LinkedList初始化
List<String> linkedList = new LinkedList<>();
linkedList.add("链表");
linkedList.add("数组");
// 首尾操作(优势)
((LinkedList<String>) linkedList).addFirst("头部");
((LinkedList<String>) linkedList).removeLast();
  1. 性能对比核心场景
java 复制代码
// 1. 随机查询对比
long start1 = System.currentTimeMillis();
for (int i = 0; i < 10000; i++) {
    arrayList.get(i); // 耗时短,O(1)
}
long end1 = System.currentTimeMillis();

long start2 = System.currentTimeMillis();
for (int i = 0; i < 10000; i++) {
    linkedList.get(i); // 耗时长,O(n)
}
long end2 = System.currentTimeMillis();

System.out.println("ArrayList查询耗时:" + (end1 - start1) + "ms");
System.out.println("LinkedList查询耗时:" + (end2 - start2) + "ms");

三、核心总结

  • 查多改少用ArrayList,随机访问是强项;
  • 增删频繁用LinkedList,首尾操作效率高;
  • 俩都线程不安全,并发场景需加锁或用CopyOnWriteArrayList。
相关推荐
ps酷教程5 小时前
Jackson 解决没有无参构造函数的反序列化问题
java
NiceCloud喜云5 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
_日拱一卒6 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
隔窗听雨眠6 小时前
Nginx网关响应慢排查手记
java·服务器·nginx
智慧物业老杨7 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
源码宝7 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
JAVA社区7 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展
金銀銅鐵7 小时前
[Java] 如何理解 class 文件中方法的 descriptor?
java·后端
云烟成雨TD8 小时前
Spring AI Alibaba 1.x 系列【63】AI Agent 长期记忆
java·人工智能·spring
憧憬成为java架构高手的小白8 小时前
苍穹外卖--day09
java·spring boot·百度