Java 集合中ArrayList与LinkedList的性能比较

一、需求:

  1. 头部插入‌:向列表头部插入10万个整数。
  2. 随机访问‌:从列表中间位置连续获取1万个元素。
  3. 头部删除‌:从列表头部连续删除10万个元素。

二、 使用ArrayList与LinkedList测试

java 复制代码
 //常量定义,用于测试操作的次数
    private static final int INSERT_COUNT = 100000;
    private static final int ACCESS_COUNT = 10000;
    private static final int DELETE_COUNT = 100000;

    public static void main(String[] args) {
        // 测试ArrayList
        List<Integer> arrayList = new ArrayList<>();
        System.out.println("ArrayList头部插入耗时: " + insertAtHead(arrayList, INSERT_COUNT) + "ms");
        System.out.println("ArrayList随机访问耗时: " + accessMiddle(arrayList, ACCESS_COUNT) + "ms");
        System.out.println("ArrayList头部删除耗时: " + deleteFromHead(arrayList, DELETE_COUNT) + "ms");
        System.out.println("***************************************************************");

        // 测试LinkedList
        List<Integer> linkedList = new LinkedList<>();
        System.out.println("LinkedList头部插入耗时: " + insertAtHead(linkedList, INSERT_COUNT) + "ms");
        System.out.println("LinkedList随机访问耗时: " + accessMiddle(linkedList, ACCESS_COUNT) + "ms");
        System.out.println("LinkedList头部删除耗时: " + deleteFromHead(linkedList, DELETE_COUNT) + "ms");
    }

    // 头部插入计时方法
    private static long insertAtHead(List<Integer> list, int count) {
        long start = System.currentTimeMillis();
        for (int i = 0; i < count; i++) {
            list.add(0, i); // 头部插入
        }
        return System.currentTimeMillis() - start;
    }

    // 中间位置随机访问计时方法
    private static long accessMiddle(List<Integer> list, int count) {
        if (list.isEmpty()) return 0;
        long start = System.currentTimeMillis();
        int middle = list.size() / 2;
        for (int i = 0; i < count; i++) {
            list.get(middle); // 访问中间元素
        }
        return System.currentTimeMillis() - start;
    }

    // 头部删除计时方法
    private static long deleteFromHead(List<Integer> list, int count) {
        long start = System.currentTimeMillis();
        for (int i = 0; i < count; i++) {
            if (!list.isEmpty()) {
                list.remove(0); // 头部删除
            }
        }
        return System.currentTimeMillis() - start;
    }

三、效果

四、总结分析:

  1. 头部插入

    • 结果 ‌:LinkedList耗时远小于ArrayList
    • 原因 ‌:ArrayList需要将后续元素向后移动(时间复杂度O(n)),而LinkedList只需修改指针(时间复杂度O(1))。
  2. 随机访问

    • 结果 ‌:ArrayList耗时远小于LinkedList
    • 原因 ‌:ArrayList基于数组实现,可直接通过索引定位(时间复杂度O(1)),而LinkedList需要从头遍历(时间复杂度O(n))。
  3. 头部删除

    • 结果 ‌:LinkedList耗时小于ArrayList
    • 原因 ‌:LinkedList只需调整头节点指针(O(1)),而ArrayList需要移动剩余元素(O(n))。

**由上述测试: ArrayList****实现了长度可变的数组,在内存中分配连续的空间,**遍历元素和随机访问元素的效率比较高LinkedList 采用链表存储方式,插入、删除元素时效率比较高

相关推荐
怦怦蓝2 分钟前
IDEA 开发邮件发送功能:全流程报错解决方案汇总
java·ide·intellij-idea·发邮件
艾莉丝努力练剑8 分钟前
【优选算法必刷100题:专题五】(位运算算法)第033~38题:判断字符是否唯一、丢失的数字、两整数之和、只出现一次的数字 II、消失的两个数字
java·大数据·运维·c++·人工智能·算法·位运算
山上三树8 分钟前
详细介绍 C 语言中的匿名结构体
c语言·开发语言·算法
大猫和小黄9 分钟前
Java开发过程中的各种ID生成策略
java·开发语言·id
繁依Fanyi11 分钟前
从初识到实战 | OpenTeleDB 安装迁移使用指南
开发语言·数据库·python
小罗和阿泽11 分钟前
java [多线程基础 二】
java·开发语言·jvm
小罗和阿泽11 分钟前
java 【多线程基础 一】线程概念
java·开发语言·jvm
悟空码字12 分钟前
SpringBoot整合Zookeeper,实现分布式集群部署
java·zookeeper·springboot·编程技术·后端开发
橘颂TA17 分钟前
线程池与线程安全:后端开发的 “性能 + 安全” 双维实践
java·开发语言·安全
bruce_哈哈哈21 分钟前
go语言初认识
开发语言·后端·golang