ArrayList、LinkedList和Vector的区别

embedded/2024/12/23 5:27:44/

ArrayList 容量默认是10,它和 Vector 的底层实现都是基于动态数组,ArrayList 的内部元素可以通过 get 和 set 方法进行访问;LinkedList的底层实现是基于双向链表当数据量很大或者操作很频繁的情况下,插入和删除元素时具有比 ArrayList 更好的性能,在 get 和 set 方面弱于 ArrayList

LinkedList 比 ArrayList 更占内存,因为 LinkedList 的每个节点除了存储元素,还要存储两个指针,一个指向前驱,一个指向后继。Vector 和 ArrayList 相似,但属于强同步类,内部由于synchronized 同步关键字的存在,其方法都是同步的,保证了线程安全。如果程序本身是线程安全的,使用ArrayLIst是更好的选择。

Vector 的扩容机制是每次请求其大小的2倍空间,ArrayList 自动扩容时,先创建一个长度为原数组长度1.5倍的新数组,然后将原数组中的数据拷贝到新数组中。如果能预估数据量,那么就给 ArrayList 分配一个较大的初始值,可以减少调整大小的开销,ArrayList支持缩容,但不会自动缩容。

LinkedLIst 实现了 Queue 和 Deque 接口,可以使用 offer、peek、poll 等方法。ArrayList根据下标以O(1)时间复杂度对元素进行访问,而LinkedList是O(n)。


http://www.ppmy.cn/embedded/111606.html

相关文章

如何识别和防范跨站脚本攻击(XSS)?

识别和防范跨站脚本攻击(XSS)需要一系列的措施,包括输入验证、输出编码、安全配置和用户教育。以下是一些关键步骤: 识别 XSS 异常行为: 观察网站行为是否异常,例如页面上突然出现未经预期的内容或功能。 …

Linux:命令行参数

目录 一、命令行参数是什么? 二、命令行参数作用 三、命令行参数如何传递给main函数? 一、命令行参数是什么? C语言中的main函数,我们发现既可以带参数,也可以不带参数。带参数的main函数如下: 参数为一…

语音电销系统电话机器人怎么用

2017年,全球人工智能核心产业规模超过370亿美元,而中国人工智能核心产业占比超过15%。随着可收集数据质量和数量的不断提高,人工智能将加速其技术创新和商业运营模式的发展。预计2020年,全球人工智能核心产业规模将达到1300亿美元…

React 中,Hook 是一个特定的概念

在 React 中,Hook 是一个特定的概念,主要是为了提供函数组件中对状态和生命周期功能的支持。它们之所以被称为 “Hooks”(钩子),是因为它们提供了一种“钩住”组件功能的方式,让你能够在函数组件中“挂钩”…

微波无源器件 3 一种用于Ka频带双极化波束形成网络的双模三路功分器

摘要: 本文给出了一种用于Ka频带的双极化工作的双模3路功分器的设计和性能。对有着三个输出端口的平衡地很好的功分的TE10和TE01模式和27.5-30GHz上优于-23dB的输入匹配可以获得相似的性能。与双模定向耦合器相连结,此三路功分器对于双极化波束形成网络具…

jmeter基准测试详解

配置基准测试策略:单线程连续发送请求5分钟 脚本:基准测试.jmx 提取码: 0000 登录接口换成自己需要的登录接口即可 一、基准测试脚本配置 线程组下添加图表插件:TPS、响应时间、服务器资源 linux服务器在serveragent目录下启动serveragen…

小程序事件函数传参

mark传参 注意点:与data-*属性不同,mark属性可以包含从触发事件的节点到根节点上所有的mark属性值。如果你在一个嵌套组件中触发了事件,你不仅可以获取到当前组件的mark数据,还可以获取到其父组件乃至根组件上绑定的mark数据 1.…

vue的ref和refs

语法 ref默认找当前组件中的,如果组件中有多个元素相同的ref值,默认找到最后一个