Java原生ArrayList解析

基本结构

Java的ArrayList是基于数组实现的动态列表,主要特点包括:

  1. 动态扩容:当元素数量超过当前容量时,自动扩容(通常增加50%)

  2. 快速随机访问:通过索引访问元素的时间复杂度为O(1)

  3. 有序集合:保持元素的插入顺序

核心实现机制

// JDK中的关键字段
transient Object[] elementData; // 存储元素的数组缓冲区
private int size; // 列表中实际元素数量
private static final int DEFAULT_CAPACITY = 10; // 默认初始容量

扩容机制

private void grow(int minCapacity) {int oldCapacity = elementData.length;int newCapacity = oldCapacity + (oldCapacity >> 1); // 1.5倍扩容if (newCapacity - minCapacity < 0)newCapacity = minCapacity;elementData = Arrays.copyOf(elementData, newCapacity);
}

时间复杂度分析

  • 访问元素:O(1)

  • 添加元素(尾部):平均O(1),最坏O(n)(需要扩容)

  • 插入/删除元素(非尾部):O(n)(需要移动元素)

自定义MyArrayList实现

package com.zsy;import java.util.Iterator;
import java.util.NoSuchElementException;
import java.util.Objects;/*** 自定义动态数组实现,支持泛型元素存储和基本列表操作** <p>本实现提供类似Java ArrayList的核心功能,包括:</p>* <ul>*   <li>动态扩容机制(默认初始容量10,按2倍扩容)</li>*   <li>支持索引访问和修改</li>*   <li>提供元素遍历功能</li>*   <li>实现基本的增删改查操作</li>* </ul>** <p><b>特性说明:</b></p>* <ul>*   <li>时间复杂度:随机访问O(1),插入/删除平均O(n)</li>*   <li>空间复杂度:O(n)</li>*   <li><b>非线程安全</b> - 多线程环境下需要外部同步</li>* </ul>** @param <E> 列表元素类型* @author zsy* @see List*/
public class MyArrayList<E> implements List<E> {/*** 当前列表中实际存储的元素数量*/private int size;/*** 列表当前分配的存储容量*/private int capacity;/*** 存储列表元素的数组缓冲区*/private Object[] elements;/*** 构造一个初始容量为10的空列表*/public MyArrayList() {this(10);}/*** 构造具有指定初始容量的空列表** @param initialCapacity 初始容量* @throws IllegalArgumentException 如果初始容量为负数*/public MyArrayList(int initialCapacity) {if (initialCapacity < 0) {throw new IllegalArgumentException("Illegal Capacity: " + initialCapacity);}this.capacity = initialCapacity;this.elements = new Object[initialCapacity];}/*** 将指定元素追加到列表末尾** @param element 要添加的元素*/@Overridepublic void add(E element) {ensureCapacity();elements[size++] = element;}/*** 在列表的指定位置插入指定元素** @param element 要插入的元素* @param index 插入位置的索引* @throws IndexOutOfBoundsException 如果索引超出范围*/@Overridepublic void add(E element, int index) {rangeCheckForAdd(index);ensureCapacity();System.arraycopy(elements, index, elements, index + 1, size - index);elements[index] = element;size++;}/*** 移除并返回列表中指定位置的元素** @param index 要移除元素的索引* @return 被移除的元素* @throws IndexOutOfBoundsException 如果索引超出范围*/@Overridepublic E remove(int index) {rangeCheck(index);E oldValue = elementData(index);int numMoved = size - index - 1;if (numMoved > 0) {System.arraycopy(elements, index + 1, elements, index, numMoved);}elements[--size] = null; // 清除引用,帮助GCreturn oldValue;}/*** 从列表中移除首次出现的指定元素** @param element 要移除的元素* @return 如果列表包含该元素则返回true*/@Overridepublic boolean remove(E element) {for (int i = 0; i < size; i++) {if (Objects.equals(element, elements[i])) {remove(i);return true;}}return false;}/*** 替换列表中指定位置的元素** @param index 要替换元素的索引* @param element 要存储的元素* @return 先前在指定位置的元素* @throws IndexOutOfBoundsException 如果索引超出范围*/@Overridepublic E set(int index, E element) {rangeCheck(index);E oldValue = elementData(index);elements[index] = element;return oldValue;}/*** 返回列表中指定位置的元素** @param index 要返回元素的索引* @return 列表中指定位置的元素* @throws IndexOutOfBoundsException 如果索引超出范围*/@Overridepublic E get(int index) {rangeCheck(index);return elementData(index);}/*** 返回列表中的元素数量** @return 列表中的元素数量*/@Overridepublic int size() {return size;}/*** 返回此列表中元素的迭代器** @return 按适当顺序包含此列表中所有元素的迭代器*/@Overridepublic Iterator<E> iterator() {return new ArrayListIterator();}// ========== 私有辅助方法 ==========/*** 确保列表有足够的容量容纳新元素*/private void ensureCapacity() {if (size == capacity) {resize();}}/*** 扩容列表存储容量*/private void resize() {int newCapacity = capacity * 2;Object[] newElements = new Object[newCapacity];System.arraycopy(elements, 0, newElements, 0, size);elements = newElements;capacity = newCapacity;}/*** 检查索引是否在有效范围内*/private void rangeCheck(int index) {if (index < 0 || index >= size) {throw new IndexOutOfBoundsException(outOfBoundsMsg(index));}}/*** 检查添加操作的索引是否在有效范围内*/private void rangeCheckForAdd(int index) {if (index < 0 || index > size) {throw new IndexOutOfBoundsException(outOfBoundsMsg(index));}}/*** 构造索引越界异常信息*/private String outOfBoundsMsg(int index) {return "Index: " + index + ", Size: " + size;}/*** 获取指定位置的元素(带类型转换)*/@SuppressWarnings("unchecked")private E elementData(int index) {return (E) elements[index];}// ========== 内部迭代器实现 ==========/*** 列表迭代器实现*/private class ArrayListIterator implements Iterator<E> {/*** 当前迭代位置*/private int cursor;/*** 检查是否还有更多元素可迭代** @return 如果迭代有更多元素则返回true*/@Overridepublic boolean hasNext() {return cursor != size;}/*** 返回迭代中的下一个元素** @return 迭代中的下一个元素* @throws NoSuchElementException 如果迭代没有更多元素*/@Overridepublic E next() {if (cursor >= size) {throw new NoSuchElementException();}return elementData(cursor++);}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/87474.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/87474.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/87474.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【力扣 简单 C】206. 反转链表

目录 题目 解法一&#xff1a;迭代 解法二&#xff1a;递归 题目 解法一&#xff1a;迭代 struct ListNode* reverse(struct ListNode* head) {struct ListNode* retHead NULL;while (head){struct ListNode* nextNode head->next;head->next retHead;retHead he…

明代大模型:智能重构下的文明再发现

引言&#xff1a;当紫禁城遇见生成式AI 一幅动态的《紫禁城图卷》正通过全息投影技术演绎永乐年间的宫廷盛景。这个虚实交融的场景&#xff0c;恰似明代大模型技术的隐喻——以人工智能为纽带&#xff0c;连接起永乐盛世的恢弘气象与数字时代的文明重构。作为人工智能与历史学…

推荐使用的Unity插件(行为树Behavior )

在 Unity 6.0 中使用 Behavior Designer 行为树插件开发 AI 系统&#xff0c;需结合其核心节点设计、变量管理和代码控制。以下是详细指南&#xff0c;整合了最新版本的最佳实践&#xff1a; &#x1f6e0;️ 1. 安装与基础配置 安装插件 通过 Unity Asset Store 安装 “Behav…

107. Java 继承 - 总结:方法重写与隐藏

文章目录 107. Java 继承 - 总结&#xff1a;方法重写与隐藏**详细解释&#xff1a;****方法重载** **总结** 107. Java 继承 - 总结&#xff1a;方法重写与隐藏 在 Java 中&#xff0c;定义与超类中的方法具有相同签名的方法时&#xff0c;不同类型的方法之间会有不同的行为。…

Spring Cloud使用Eureka调用接口,超时设置(二)

在 Spring Cloud 微服务架构中&#xff0c;当同时配置了 Ribbon 和 Feign 的超时时间时&#xff0c;Feign 的配置优先级高于 Ribbon。具体规则和底层逻辑如下&#xff1a; ⚙️ 1. 配置优先级规则 Feign 显式配置 > Ribbon 配置 若在 Feign 中显式设置了超时时间&#xff0…

iOS-SM3加密算法N种集成

近期的一个项目需要用到SM3加密算法&#xff0c;需要在iOS中使用Objective-C实现SM3国密加密算法。 SM3&#xff1a;是中国国家密码管理局发布的密码杂凑算法标准&#xff0c;适用于商用密码应用中的数字签名和验证、消息认证码的生成与验证以及随机数的生成等 由于iOS系统并未…

[逆向工程]什么是TEB 与 PEB(二十九)

[逆向工程]什么是TEB 与 PEB(二十九) 一、引言:为什么需要了解 TEB/PEB? 在 Windows 系统开发、调试或逆向工程中,TEB(Thread Environment Block) 和 PEB(Process Environment Block) 是理解程序执行机制的关键。它们如同进程与线程的“身份证”,存储了从内存布局到…

逆向分析贝壳网人机验证JS加密逻辑

引言 在数据爬取和自动化测试过程中&#xff0c;人机验证&#xff08;如滑块、点选、短信验证等&#xff09;是常见的反爬手段。贝壳网&#xff08;ke.com&#xff09;作为国内领先的房产平台&#xff0c;其人机验证机制较为复杂&#xff0c;涉及前端JS加密、动态Token、行为检…

Vue3 + Element Plus中el-table加载状态分析

在 Vue 3 中&#xff0c;当 onMounted 钩子被触发时&#xff0c;父组件的 DOM 已经挂载完成&#xff0c;但子组件&#xff08;如 el-table&#xff09;可能尚未完成其内部渲染。具体分析如下&#xff1a; 1. onMounted 的执行时机 父组件挂载完成&#xff1a;onMounted 表示当前…

OpenCV图像拼接技术详解:从特征匹配到全景合成

本文将详细介绍如何使用OpenCV实现两幅图像的自动拼接&#xff0c;涵盖特征提取、单应性矩阵计算和图像融合等关键技术。 一、图像拼接概述 图像拼接是将多张有重叠区域的图像合并成一幅全景图的技术&#xff0c;广泛应用于全景摄影、卫星图像处理、医学影像等领域。其核心技术…

如何通过 5 种方式向 Android 手机添加音乐

想把音乐添加到你的安卓手机&#xff0c;然后随时随地无需网络连接就能欣赏你喜爱的音乐吗&#xff1f;这不再是麻烦。现在&#xff0c;你可以按照本指南中的有效方法&#xff0c;将音乐添加到你的安卓手机上。让我们在安卓手机上聆听我们美妙的歌曲吧。 第 1 部分&#xff1a;…

VS Code 项目中的 .vscode 目录详解

VS Code 项目中的 .vscode 目录详解 .vscode 目录是 VS Code 项目的核心配置中心&#xff0c;它包含特定于当前项目的配置&#xff0c;这些配置覆盖全局设置&#xff0c;确保团队成员获得一致的开发环境体验。 .vscode 目录中的核心文件 文件名作用是否应纳入版本控制settin…

Ubuntu22.04安装opengauss并配置远程访问、JDBC连接

内容概括 最近在研究怎么在ubuntu服务器环境下使用opengauss&#xff0c;看了下官方下载地址没有适配ubuntu的安装包。仔细翻了下官方文档&#xff0c;发现安装指南里有提供一个deb包安装方案&#xff0c;有适配ubuntu&#xff0c;经过实践可行&#xff0c;于是记录下来给有需要…

国产智能体“双子星”:实在Agent vs Manus(核心架构与技术实现路径对比)

2025年&#xff0c;人工智能领域迎来重要转折点——大模型的光环逐渐消散&#xff0c;落地应用成为行业焦点。 正如业内人士所言&#xff1a;“2023年&#xff0c;大家普遍觉得要买一个大模型&#xff0c;但训练完了怎么用起来&#xff0c;大家一头雾水。” 在这一背景下&…

pgAdmin 4 连接 postgreSQL

环境如下&#xff1a; 宿主机为Windows 11postgreSQL安装在宿主机上的Linux虚机中&#xff0c;Hypervisor是VirtualBoxpgAdmin 4 已安装在宿主机上 本文讲述&#xff1a;如何通过宿主机上的pgAdmin 连接到虚拟机中的PG。 设置监听 默认的PG监听主机为localhost&#xff0c;…

HTTP 缓存策略:强缓存与协商缓存的深入解析

在HTTP缓存策略中&#xff0c;强缓存和协商缓存是两种常用的机制&#xff0c;用于减少数据传输和提高网页加载速度。它们通过在客户端和服务器之间建立缓存来避免不必要的网络请求&#xff0c;从而优化性能并提高用户体验。本文将详细介绍这两种缓存策略的原理、优势和适用场景…

Node.js 中的 Token 认证机制详解

文章目录 Node.js 中的 Token 认证机制详解1. Token 认证基础1.1 什么是 Token 认证&#xff1f;1.2 Token 认证流程 2. JWT (JSON Web Token) 实现2.1 安装依赖2.2 生成 Token2.3 验证 Token 中间件 3. 完整实现示例3.1 登录接口3.2 受保护的路由 4. Token 安全最佳实践5. Tok…

23 - HaLoAttention模块

论文《Scaling Local Self-Attention for Parameter Efficient Visual Backbones》 1、作用 HaloNet通过引入Haloing机制和高效的注意力实现&#xff0c;在图像识别任务中达到了最先进的准确性。这些模型通过局部自注意力机制&#xff0c;有效地捕获像素间的全局交互&#xf…

2025Mybatis最新教程(五)

第5章 ORM映射 5.1 MyBatis自动ORM失效 MyBatis只能自动维护库表”列名“与”属性名“相同时的对应关系,二者不同时,无法自动ORM。 自动ORM失效建表 create table t_managers(mgr_id int primary key auto_increment,mgr_name varchar(50),mgr_pwd varchar(50) ); 添加数据…

解决lombok注解失效问题

Lombok 注解失效是 Java 开发中的常见问题&#xff0c;通常由依赖配置、IDE 支持或构建工具设置引起。最近在拉取别人springboot3jdk21版本的项目时遇到了lombok注解失效&#xff0c;导致项目无法启动的问题&#xff0c;以下是我的解决方案&#xff1a; 首先检查idea 的lombok…