JAVA ArrayList集合底层源码分析
ArrayList集合
一、ArrayList的注意事项

ArrayList集合可以加入null,并且可以加入多个ArrayList是由数组来实现的数据存储的ArrayList基本等同于Vetor,但是ArrayList是线程不安全的(执行效率高),在多线程下不建议使用ArrayList
二、 ArrayList 的底层操作机制源码分析(重点,难点.)
1.JDK8.0

- ArrayList中存放了一个Object类型的数组elementDate,什么类型都能往里面放
transient Object[] elementDate;transient,表示该属性不会被序列化
- 当创建
ArrayList对象时,如果使用的是无参构造器,则初始elementData容量为0,第1次添加,则扩容elementData为10,如需要再次扩容,则扩容elementData为1.5倍 - 如果使用的是指定大小的构造器,则初始
elementData容量为指定大小,如果需要扩容,则直接扩容elementData为1.5倍。


注意:
- mount 表示的该数组的修改次数


注意:
>>1代表二进制位向右移两位,表示大小/2,这里的int newCapacity = oldCapacity + (oldCapacity >> 1),代表扩容按旧数组的1.5倍进行扩容(除第一次).newCapacity - minCapacity < 0- 第一次扩容:
newCapacity = 0,minCapacity = 10,即当最小容量比新容量小的时候,把minCpacaity赋给newCapacity,只有第一次扩容会执行这个if- 如果newCapacity 比最大的大小还要大时
- 执行hugeCapacity这个方法
- 利用
copyOf,把原数组的内容拷贝到新数组里面去,并让elementData指向该方法返回回来的地址,这样可以在保留原来数组中元素的同时,并增加新的空间,新空间默认为null;
- 第一次扩容:

若是使用指定大小的构造器

- 第一次扩容就按照elemenData的1.5倍扩容
- 整个执行流程还是和前面讲的一样
2.JDK11.0


使用ArrayList无参构造器,会创建一个只读的静态的,类型为Object的空数组
存储数据底层实现原理:

- 调用add方法,参数:
e为你要存储的数据(大概). modCount:为对该集合的操作次数,默认为0- 调用 add 方法(重载后的add方法)

- 当前元素个数 == 当前数组长度,就会进行扩容
- 之后让
elementData[s] = e,s为当前元素个数,且让size = s +1;
- 之后让
- 如果要进行扩容

- 返回一个扩容后的数组,利用
copyOf方法,把原来的数组元素,拷贝到新数组中,且新数组的长度为原来数组+1; - 然后在执行下面的赋值操作,同上
newCapacity方法

- 调用newCapacity,确定要扩大的空间
- oldCapacity 为当前数组的长度
- newCapacity 为扩容后新数组的长度:为旧数组长度的1.5倍
如果新数组的长度,比需要的(最小)容量小,则执行下面的代码
DEFAULT_CAPACITY为int 类型 ,值为10,如果elementaData 为空数组(DEFAULTCAPACTY_EMPTY_ELEMENTDATA),那么就用把mincapacity和DEFAULT_CAPACITY传进去进行比较,返回最大值,这个最大值就是要新数组的容量- 如果minCapacity<0 则抛出异常
- 并返回mincapacity
如果新数组的长度,大于需要的(最小)容量,则执行下面的代码
- 三元表达式,这里比较简单不做阐述
JAVA ArrayList集合底层源码分析的更多相关文章
- 设计模式(十七)——迭代器模式(ArrayList 集合应用源码分析)
1 看一个具体的需求 编写程序展示一个学校院系结构:需求是这样,要在一个页面中展示出学校的院系组成,一个学校有多个学院, 一个学院有多个系.如图: 2 传统的设计方案(类图) 3 传统的方式的问题分析 ...
- Java的LinkedList底层源码分析
首先我们先说一下,源码里可以看出此类不仅仅用双向链表实现了队列数据结构的功能,还提供了链表数据结构的功能.
- List-ArrayList集合基础增强底层源码分析
List集合基础增强底层源码分析 作者:Stanley 罗昊 [转载请注明出处和署名,谢谢!] 集合分为三个系列,分别为:List.set.map List系列 特点:元素有序可重复 有序指的是元素的 ...
- List-LinkedList、set集合基础增强底层源码分析
List-LinkedList 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 继上一章继续讲解,上章内容: List-ArreyLlist集合基础增强底层源码分析:https:// ...
- 你真的了解java的lambda吗?- java lambda用法与源码分析
你真的了解java的lambda吗?- java lambda用法与源码分析 转载请注明来源:cmlanche.com 用法 示例:最普遍的一个例子,执行一个线程 new Thread(() -> ...
- ArrayList详解-源码分析
ArrayList详解-源码分析 1. 概述 在平时的开发中,用到最多的集合应该就是ArrayList了,本篇文章将结合源代码来学习ArrayList. ArrayList是基于数组实现的集合列表 支 ...
- Vector总结及部分底层源码分析
Vector总结及部分底层源码分析 1. Vector继承的抽象类和实现的接口 Vector类实现的接口 List接口:里面定义了List集合的基本接口,Vector进行了实现 RandomAcces ...
- LInkedList总结及部分底层源码分析
LInkedList总结及部分底层源码分析 1. LinkedList的实现与继承关系 继承:AbstractSequentialList 抽象类 实现:List 接口 实现:Deque 接口 实现: ...
- java线程池ThreadPoolExector源码分析
java线程池ThreadPoolExector源码分析 今天研究了下ThreadPoolExector源码,大致上总结了以下几点跟大家分享下: 一.ThreadPoolExector几个主要变量 先 ...
随机推荐
- 记一次 .NET 某智能交通后台服务 CPU爆高分析
一:背景 1. 讲故事 前天有位朋友加微信求助他的程序出现了CPU爆高的问题,开局就是一个红包,把我吓懵了! 由于是南方小年,我在老家张罗处理起来不方便,没有第一时间帮他处理,朋友在第二天上午已经找出 ...
- Java 继承02
向上类型转换 父类型的引用指向子类型的实例. Person p = new Person();Animal a = p; //子类对象赋值给父类类型的变量 注意: 向上转型后,子类单独定义的方法会丢失 ...
- AWS SAA_C01 考试分享。
Saa-c01 经验分享! 序言1.介绍自己的情况,我是一个做后台开发的初级java程序员.还是处于在写业务逻辑的阶段,我对aws可谓是啥都不懂,纯种的小白,完全是从0基础开始学习的.希望分享一些我的 ...
- 计算机网络-5-10-TCP运输连接管理
TCP的运输连接管理 TCP是面向连接的通信,运输连接是用来传送TCP报文的,TCP运输连接的建立和释放是每一次面向连接的通信中必不可少的过程.因此,运输连接有三个阶段,即:建立连接,数据传送,连接释 ...
- Hive安装教程
Hive的安装和使用 我的版本: JAVA_HOME=/usr/local/soft/jdk1.8.0_171 HADOOP_HOME=/usr/local/soft/hadoop-2.7.6 HIV ...
- java中使用反射获取pojo(实体)类的所有字段值
出处:https://developer.aliyun.com/article/239346 说起反射,不得不说它实在是太强大了,通过反射就可以轻轻松松拿到各种东东,如果你想在项目中解除对某个类的依赖 ...
- StarUML官网地址 http://staruml.io/
StarUML官网地址 http://staruml.io/
- Android 四种方法写按钮点击事件
1.匿名内部类的方式 2. 创建一个类实现onclickListener,实现onclick方法,设置控件点击事件时传一个类的对象. 3. 让当前类实现onclickListener,设置控件点击事件 ...
- 模仿系统的UIImageView
整体思路: 我们想要模仿系统的UIImageView,我们必须得要知道系统的UIView怎么用. 系统的用法是创建一个UIImageView对象,设置frame,给它传递一个UIIma ...
- VC 获取当前运行窗口名称
转载请注明来源:https://www.cnblogs.com/hookjc/ BOOL CALLBACK WindowChild(HWND hwnd,LPARAM lparam){ CFGDlg* ...