性能篇:List集合遍历元素用哪种方式更快?

嗨大家好,我是小米!今天给大家分享一篇关于Java集合框架性能的文章,话题是:"如果让你使用 for 循环以及迭代循环遍历一个 ArrayList,你会使用哪种方式呢?原因是什么?LinkedList呢?"废话不多说,让我们直入主题!

ArrayList的get元素源码介绍

ArrayList,作为Java集合框架中的一个重要类,是基于数组实现的动态数组。其get方法是用于获取指定索引位置的元素。让我们深入挖掘这个方法的源码。

在ArrayList的get 方法中,首先通过rangeCheck(index) 方法来检查索引是否越界。这是为了确保用户传入的索引在合法范围内。一旦索引通过了检查,便直接通过elementData[index] 来获取对应位置的元素。这一过程是非常高效的,因为底层数据结构是一个数组,通过索引直接访问元素的时间复杂度是O(1)。

这种直接访问的机制使得ArrayList在读取元素时具有较好的性能表现,尤其是当我们需要按索引随机访问元素时。数组的随机访问特性使得ArrayList在元素检索上迅速而高效。

源码解析

下面是 ArrayListget方法的关键源码:

LinkedList的get元素源码介绍

LinkedList是Java集合框架中基于双向链表实现的动态列表,它的get方法用于获取指定索引位置的元素。让我们深入探讨这个方法的源码。

在LinkedList的get 方法中,首先通过checkElementIndex(index) 方法来检查传入的索引是否合法。这是为了确保用户传入的索引在链表的有效范围内,防止发生越界访问。一旦索引通过了检查,接下来调用node(index) 方法获取对应位置的节点。

node(index) 方法的作用是从链表的头节点或尾节点出发,根据索引逐步遍历链表,直到找到目标位置的节点。这一过程需要遍历链表,因此时间复杂度是O(n)。一旦找到目标节点,通过node(index).item来获取节点中存储的元素。

源码解析

下面是 LinkedListget方法的关键源码:

get元素操作JMH测试

为了更直观地比较两者的性能,我们使用JMH(Java Microbenchmarking Harness)进行测试。以下是测试代码片段:

测试结论

通过JMH测试,我们可以看到,LinkedList 的 for 循环性能是最差的,而 ArrayList 的 for 循环性能是最好的。

这是因为 LinkedList 基于链表实现的,在使用 for 循环的时候,每一次 for 循环都会去遍历半个 List,所以严重影响了遍历的效率;ArrayList 则是基于数组实现的,并且实现了 RandomAccess 接口标志,意味着 ArrayList 可以实现快速随机访问,所以 for 循环效率非常高。

LinkedList 的迭代循环遍历和 ArrayList 的迭代循环遍历性能相当,也不会太差,所以在遍历 LinkedList 时,我们要切忌使用 for 循环遍历。

END

在本文中,我们深入探讨了Java集合框架中ArrayList和LinkedList两个重要的数据结构在get元素操作上的差异。通过分析源码,我们了解到ArrayList通过数组实现,具有直接访问元素的优势,而LinkedList则通过链表实现,需要遍历节点。进而,我们通过JMH性能测试量化了它们在具体应用场景中的性能表现,帮助开发者根据需求做出合理的选择。

这篇文章旨在帮助读者更深入理解这两种数据结构的底层实现和性能特点,为实际项目中的选择提供了指导。希望本文对大家在Java集合框架中的数据结构选择有所启发,有任何问题或意见,欢迎留言讨论!感谢阅读!

如有疑问或者更多的技术分享,欢迎关注我的微信公众号"知其然亦知其所以然"!

相关推荐
rengang667 小时前
353-Spring AI Alibaba ARK 多模型示例
java·人工智能·spring·多模态·spring ai·ai应用编程
程序新视界7 小时前
MySQL的数据库事务、ACID特性以及实战案例
数据库·后端·mysql
kaikaile19957 小时前
深入理解RESTful API设计
后端·restful
bst@微胖子8 小时前
阿里通义千问推理优化上下文缓存之隐式缓存和显式缓存
java·spring·缓存
ss2738 小时前
手写Spring第20弹:JDK动态代理:深入剖析Java代理模式
后端·spring·代理模式
后端小张8 小时前
【JAVA 进阶】重生之我要学会 JUC 并发编程
java·spring boot·spring·java-ee·并发编程·安全架构·juc
重整旗鼓~8 小时前
33.点赞功能
java
JaguarJack8 小时前
PHP 组件未来:Livewire 4 正式发布,性能更快,功能更完整
后端·php
洛克大航海8 小时前
9-SpringCloud-服务网关 Gateway-高级特性之 Filter-2
java·spring cloud·gateway·filter
无知就要求知8 小时前
golang封装可扩展的crontab
开发语言·后端·golang