Java 集合框架之线性表(List)实现技术笔记

一、核心概念

  • 线性表:有序数据结构,支持元素的增删改查、排序、比较等操作,核心实现方式为数组实现和链表实现。
  • 泛型(E):定义线性表存储的数据类型,使用时指定具体类型(如 String、Integer),避免类型转换错误。
  • 接口与实现:List 接口定义统一方法规范,ZArrayList 类基于数组实现该接口,遵循"接口定义规范、实现类完成具体逻辑"的设计思路。

二、List 接口核心方法(按功能分类)

1. 基础查询

  • size() :返回元素个数
  • isEmpty() :判断线性表是否为空
  • get(int index) :根据下标获取元素
  • contains(E e) :判断元素是否存在
  • indexOf(E e) / lastIndexOf(E e) :获取元素首次/末次出现下标(不存在返回 -1)

2. 元素添加

  • 单个添加: add(E e) (尾部添加)、 insert(int index, E e) (指定下标插入)
  • 批量添加: addAll(E[] es) / addAll(List list) (尾部合并)、 insertAll(int index, E[] es) / insertAll(int index, List list) (指定下标批量插入)

3. 元素删除

  • 单个删除: remove(int index) (按下标删除,返回被删元素)
  • 批量删除: removeByElement(E e) (按元素删除,返回删除数量)、 removeRange(int fromIndex, int toIndex) (按区间删除)、 removeByList(List list) (按集合删除)

4. 元素替换与排序

  • 替换: replace(int index, E e) (按下标替换)、 replaceByElement(E e1, E e2) (按元素替换)、 replaceAll(List list) (按集合替换)
  • 比较: equals(List list) (判断两个集合是否相同)

5. 其他功能

  • clear() :清空线性表,恢复初始容量
  • subList(int fromIndex) / subList(int fromIndex, int toIndex) :截取元素(切片)
  • toArray() :将线性表转为新数组返回

三、ZArrayList 实现关键细节

1. 核心属性

java 复制代码
  
private int size; // 实际元素个数
private int length; // 数组容量
private Object[] values; // 存储元素的数组
private static final int DEFAULT_CAPACITY = 10; // 默认初始容量

2. 构造方法

  • 无参构造:默认初始化容量为 10, values = new Object[DEFAULT_CAPACITY]
  • 有参构造:指定初始容量(若≤2则使用默认值10)

3. 扩容机制(核心亮点)

  • 触发条件:当实际元素个数 size == 数组容量 length 时触发扩容
  • 扩容规则:新容量 = 旧容量 + 旧容量右移1位(即 newLength = oldLength + (oldLength >> 1) ,等价于1.5倍扩容)
  • 实现逻辑:创建新数组 → 迁移旧数组元素 → 替换引用并更新容量

4. 关键方法实现要点

  • add(E e) :先检查是否需要扩容,再通过 values[size++] = e 尾部添加(size++ 先赋值后自增)
  • insert(int index, E e) :先校验下标合法性(0≤index≤size),扩容后迁移index后的元素,空出位置插入新元素
  • get(int index) :校验下标合法性(0≤index<size),通过 (E) values[index] 强转返回元素(泛型适配)

四、注意事项与易错点

  1. 下标合法性:所有涉及下标的操作(get、insert、remove等)需校验 index ≥ 0 且 index ≤ size (插入时允许index=size,即尾部插入)
  2. size与length区别:size是实际元素个数,length是数组容量,扩容只更新length,不改变当前size
  3. 泛型强转:Object数组存储元素后,通过 (E) 强转为泛型类型,需确保使用时类型一致
  4. size++与++size: add(E e) 中使用 values[size++] = e ,先将元素存入size位置,再让size自增(若用++size会跳过0下标)

五、总结

ZArrayList 基于数组实现线性表,核心优势是随机访问效率高(通过下标直接获取元素),扩容机制采用1.5倍增长平衡空间利用率与性能。需重点掌握接口方法规范、扩容逻辑、下标校验三大核心点,后续可补充未实现方法(如 contains、removeByElement),并对比链表实现的差异(如插入效率、空间占用)。

相关推荐
程序员小假22 分钟前
我们来说一下无锁队列 Disruptor 的原理
java·后端
clorisqqq26 分钟前
人工智能现代方法笔记 第1章 绪论(1/2)
人工智能·笔记
charlie11451419127 分钟前
嵌入式现代C++教程: 构造函数优化:初始化列表 vs 成员赋值
开发语言·c++·笔记·学习·嵌入式·现代c++
资生算法程序员_畅想家_剑魔36 分钟前
Kotlin常见技术分享-02-相对于Java 的核心优势-协程
java·开发语言·kotlin
ProgramHan40 分钟前
Spring Boot 3.2 新特性:虚拟线程的落地实践
java·jvm·spring boot
nbsaas-boot1 小时前
Go vs Java 的三阶段切换路线图
java·开发语言·golang
!chen1 小时前
Error: error:0308010C:digital envelope routines::unsupporte
python
毕设源码-钟学长2 小时前
【开题答辩全过程】以 基于Java的慕课点评网站为例,包含答辩的问题和答案
java·开发语言
wdfk_prog2 小时前
[Linux]学习笔记系列 -- [fs]seq_file
linux·笔记·学习
小北方城市网2 小时前
分布式锁实战指南:从选型到落地,避开 90% 的坑
java·数据库·redis·分布式·python·缓存