Java基础数据结构之ArrayList源码分析

一.几个常量

这是默认容量

这两个是共享的空对象

这是真正存储元素的地方,现在还没有分配内存

二.构造方法

这是一个无参构造方法,此时让存储元素的数组指向了那个默认容量数组,此时该数组是一个空数组,长度为0.

这是给定初始容量的构造方法,第一个if里面,让elementdata指向了一个新数组,而没有共享那俩个空数组,但如果给定的初始容量为0,就会共享那个空数组

这个构造方法的参数是一个实现了Collection接口的类,其中的数据必须是E或E的子类。例如:

我们再看源码 elementData = c.toArray(); 这是Collection接口中的一个抽象方法:

注意,其返回值是Object[]

构造方法中的第一个if是为了将elementData变成Object类,因为ArrayList是基于Object进行操作的

注意getClass得到的是运行时类型,比如

p的编译时类型是Person类,p的运行时类型是Student类,getClass得到的是Student类

三.ArrayList扩容机制之add方法

1.在末尾添加元素

调用第一个方法是传入了所需最小容量,即当前size+1

如果所需容量小于当前数组的长度,就要grow即扩容

旧容量是数组长度,新容量是旧容量的1.5倍!!如果新容量小于所需容量,就让新容量等于所需容量,然后扩容,用到copyOf方法

总结:

对于调用了无参构造方法的list,它的elementData指向了那个共享的空数组,长度为0,当第一次添加元素时,会进入如下方法:

其中恰好可以进入if语句,所以会返回DEFAULT_CAPACITY即10,然后如下函数接收:

然后1.5倍扩容

在第二次添加时,elementData不再指向DEFAULTCAPACITY_EMPTY_ELEMENTDATA,所以calculateCapacity方法返回的是minCapacity即2,所以就不会进入grow方法

2.在指定位置添加元素

首先是检查下标的合法性,其次就是确定容量,然后就是元素后移,最后就是放置元素

四.其他方法

1.trimToSize()方法

目的是缩小数组大小,比如数组长度是10,但只有3个元素,就将数组大小缩小为3

2.indexOf方法

返回元素第一次出现时对应的下标

3.lastIndexOf

返回最后一次出现时对应的下标

4.

super.clone()是一个浅拷贝,只是将链表的表面克隆过来了,链表内部的elementData没有克隆一份,而是与之前的elementData共享这一个空间,所以还要对elementData单独进行克隆。

5.toArray方法

注意,其返回值是Object类型,接收时是否可以应Integer类型接收并进行向下转型?

报错了,这是因为在java中,父类引用可以指向子类实例,但反过来就不可以。toArray方法返回的是一个父类的实例对象,就不能用子类引用去接收。所以可以用到下面的toArray方法

a是一个将要存储列表元素的数组,如果a的长度小于列表中的元素个数,就会重新创建一个数组,该数组长度等于列表中元素个数,类型和a的类型一致;

如果a的大小足够大,就会将elementData中的元素拷贝到a中。如果拷贝后还有剩余空间,则会将a中紧接在集合结束后的元素设置为null

看效果:

6.clear方法

将元素置为null

7.retainAll方法

A.retainAll(B)表示将存在于A中但不存在于B中的元素移除,并更新size

8.subList方法

返回一个子顺序表,注意区间是左闭右开

五.遍历ArrayList

这俩个方法返回了一个Itr对象,Itr是ArrayList里面自定义的一个内部类,该类实现了Iterator接口,如下:

注意,Iterator是一个接口,ListIterator接口继承了该接口,如下:

所以可以如下使用:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/363832.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C#使用OpenCvSharp4库读取电脑摄像头数据并实时显示

一、OpenCvSharp4库 OpenCvSharp4库是一个基于.Net封装的OpenCV库,Github源代码地址为:https://github.com/shimat/opencvsharp,里面有关于Windows下安装OpenCvSharp4库的描述,如下图所示: 二、C#使用OpenCvSharp4库…

杂题——试题-算法训练-P0604-runaround数

分析: 题目有三个关键点: 一:结束时,回到起始位置(比较结束时和起始时的下标位置是否相同)二:该整数的所有数字都必须遍历一遍,且只能遍历一遍(把遍历过的数字做个标记&a…

【前端-VUE+TS】Vue3组件化-知识补充(六)

一. 动态组件 比如我们现在想要实现了一个功能: 点击一个tab-bar,切换不同的组件显示; 案例截图 这个案例我们可以通过两种不同的实现思路来实现: 方式一:通过v-if来判断,显示不同的组件;方式二…

周润发节俭,排队买廉价盒饭,身价56亿由此省出。

♥ 为方便您进行讨论和分享,同时也为能带给您不一样的参与感。请您在阅读本文之前,点击一下“关注”,非常感谢您的支持! 文 |猴哥聊娱乐 编 辑|徐 婷 校 对|侯欢庭 周润发裸捐数十亿,但生活中的他却极度节俭。每一分…

基于SSM的高校社团管理系统

末尾获取源码作者介绍:大家好,我是墨韵,本人4年开发经验,专注定制项目开发 更多项目:CSDN主页YAML墨韵 我欲乘风归去 又恐琼楼玉宇 高处不胜寒 -苏轼 目录 一、项目简介 二、开发技术与环境配置 2.1 SSM框架 2.2 …

UGUI中Text和TextMeshPro实现图文混排方式

一些项目中实现图文混排是自定义一个脚本去继承Text类,然后文本中用富文本的方式进行图片和超链接的定义,在代码中用正则表达式匹配的方式把文本中图片和超链接给替换,如下: TextMeshPro实现是生成SpriteAsset进行图文混排的&…

杂题——试题 算法训练 试题3971 丑数

分析: 判断一个数 n 是否是丑数,分成三个部分 1、寻找因数,从2遍历到 n,如果该数 i 是 n 的因数,就进入下一步2、判断 i 是否是质数,这部分代码直接套用即可,见得较多3、最后判断 i 是否等于2或…

2024 springboot Mybatis-flex 打包出错

Mybatis-flex官网:快速开始 - MyBatis-Flex 官方网站 从 Mybatis-flex官网获取模板后,加入自己的项目内容想打包确保错,先试试一下方法 这里改成skip的默认是true改成false,再次打包就可以了

ATFX汇市:鲍威尔否认3月降息,晚间英央行决议大概率按兵不动

ATFX汇市:今日3:00,美联储公布利率决议结果,维持5.5%的联邦基金利率不变,美元指数五分钟内上涨0.19%,最高触及103.51点。半小时后的3:30,美联储主席鲍威尔开始讲话,美元指数分钟级别剧烈下跌&am…

【服务端性能测试】测试方案设计(实操需要准备的内容)

一般性能测试流程都是:获取测试需求——>测试需求分析——>测试方案设计——>压测环境搭建(目前是线上)——>测试数据准备——>测试脚本准备、调试——>测试脚本执行——>监控数据录入——>测试结果跟开发一起分析—…

设计模式——模板方法模式(Template Method Pattern)

概述 模板方法模式:定义一个操作中算法的框架,而将一些步骤延迟到子类中。模板方法模式使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。模板方法模式是一种基于继承的代码复用技术,它是一种类行为型模式。模板方法模式是结…

TCP 协议的相关特性

1. TCP格式 TCP特性:有连接,全双关,面向字节流,可靠传输。(TCP安身立命的本钱,初心就是解决“可靠传输”问题) 其实TCP的特征有很多这里我就简单的介绍几个。 2. 确认应答 其实用来确保可靠性&…

【新课】安装部署系列Ⅲ—Oracle 19c Data Guard部署之两节点RAC部署实战

本课程由云贝教育-刘峰老师出品,感谢关注 课程介绍 Oracle Real Application Clusters (RAC) 是一种跨多个节点分布数据库的企业级解决方案。它使组织能够通过实现容错和负载平衡来提高可用性和可扩展性,同时提高性能。本课程基于当前主流版本Oracle 1…

2024.1.30 GNSS 学习笔记

站星双差Kalman滤波伪距差分定位流程 1. RTK定位技术(实时载波相位差分技术)原理-站间单差浮点解 1.RTK技术其实就是在RTD技术的基础上增加载波观测值的使用。由于伪距的噪声在分米量级,即使我们通过站间单差消除了绝大部分的误差影响&…

前端入门第二天

目录 一、列表、表格、表单 二、列表(布局内容排列整齐的区域) 1.无序列表(不规定顺序) 2.有序列表(规定顺序) 3.定义列表(一个标题多个分类) 三、表格 1.表格结构标签 2.合并…

基于Raspberry Pi的自动巡航与避障系统(二)

在上一篇中,我们讨论了智能小车的避障逻辑实现,在本篇中,我们将进一步扩展智能小车的功能,包括更高级的避障策略、路径规划和导航功能,同时,我们还将提供相应的代码示例,以帮助读者更好地理解和…

Typora导出html文件图片自动转换成base64

Typora导出html文件图片自动转换成base64 一、出现问题二、解决方案三、编码实现3.1.创建Java项目3.2.代码3.3.打包成Jar包 四、如何使用endl 一、出现问题 typora 导出 html 的时候必须带有原图片,不方便交流学习,文件太多显得冗余,只有将图…

GNSS技术助力航海业迈向新时代:海洋测绘与航行的创新应用

全球导航卫星系统(GNSS)技术在海洋测绘与航行领域的广泛应用,正推动航海业迎来新一轮的科技变革。MinewSemi的GNSS模块为船舶导航、海洋资源勘探和航行安全提供了更为精确和高效的解决方案。本文将深入研究GNSS技术在海洋测绘与航行中的创新应…

开源:基于Vue3.3 + TS + Vant4 + Vite5 + Pinia + ViewPort适配..搭建的H5移动端开发模板

vue3.3-Mobile-template 基于Vue3.3 TS Vant4 Vite5 Pinia ViewPort适配 Sass Axios封装 vconsole调试工具,搭建的H5移动端开发模板,开箱即用的。 环境要求: Node:16.20.1 pnpm:8.14.0 必须装上安装pnpm,没装的看这篇…

基于PSO-BP神经网络的风电功率MATLAB预测程序

微❤关注“电气仔推送”获得资料(专享优惠) 参考文献 基于风电场运行特性的风电功率预测及应用分析——倪巡天 资源简介 由于自然风具有一定的随机性、不确定性与波动性,这将会使风电场的功率预测受到一定程度的影响,它们之间…