Java集合篇——List

ArrayList、LinkedKist、Vector的区别

List主要有ArrayList、LinkedList与Vector几种实现。这三者都实现了List接口,使用方式也很相似主要区别在于因为实现方式的不同,所以对不同的操作具有不同的效率。

**ArrayList是一个可改变大小的数组,**当更多的元素加入到ArrayList中时,其大小将会动态地增长.内部的元素可以直接通过get与set方法进行访问,因为ArrayList本质上就是一个数组。

LinkedList是一个双向链表,在添加和删除元素时具有比ArrayList更好的性能,但在get与set方面弱于ArrayList。当然这些对比都是指数据量很大或者操作很频繁的情况下的对比,如果数据和运算量很小那么对比将失去意义。

Vector和ArrayList类似但属于强同步类。如果你的程序本身是线程安全的(thread-safe,没有在多个线程之间共享同一个集合/对象)那么使用ArrayList是更好的选择。

Vecto和ArrayList在更多元素添加进来时会请求更大的空间。Vector每次请求其大小的双倍空间,而ArrayList每次对size增长50%。

而LinkedList还实现了Queue和Deque接口,该接口比List提供了更多的方法,包括offer(),peek(),poll()等。

ArrayList是如何扩容的?

首先,我们要明白ArrayList是基于数组的,我们都知道,申请数组的时候,只能申请一个定长的数组,那么List是如何通过数组扩容的呢?ArrayList的扩容分为以下几步:

1.检查新增元素后是否会超过数组的容量,如果超过,则进行下一步扩容

2.设置新的容量为老容量的1.5倍,最多不超过231-1(Java8中ArrayList的容量最大是

Integer.MAXVALUE-8,即231-9。这是由于在Java8中,ArrayList内部实现进行了一些改进,使用了些数组复制的技巧来提高性能和内存利用率,而这些技巧需要额外的8个元素的空间来进行优化。

3.之后,申请一个容量为1.5倍的数组,并将老数组的元素复制到新数组中,扩容完成

相关推荐
阿里嘎多学长2 小时前
2026-04-30 GitHub 热点项目精选
开发语言·程序员·github·代码托管
abcnull3 小时前
用javaparser做精准测试
java·ast·静态代码分析·精准测试·javaparser
叶小鸡3 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
juniperhan4 小时前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
ID_180079054734 小时前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
c++之路4 小时前
C++23概述
java·c++·c++23
时空系4 小时前
第10篇:继承扩展——面向对象编程进阶 python中文编程
开发语言·python·ai编程
专注API从业者5 小时前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库
CHANG_THE_WORLD5 小时前
python 批量终止进程exe
开发语言·python