ArrayList应用
来源:互联网 发布:网络销售聊天技巧话术 编辑:程序博客网 时间:2024/06/06 04:54
ArrayList是基于数组实现的,是一个动态数组,其容量能自动增长。ArrayList不是线程安全的,只能用在单线程环境下。实现了Serializable接口,因此它支持序列化,能够通过序列化传输;实现了RandomAccess接口,支持快速随机访问,实际上就是通过下标序号进行快速访问;实现了Cloneable接口,能被克隆。
本文我们主要了解Arraylist如何动态扩容;
动态扩容
代码解析,如何能实现动态数组,怎么样管理容量?
一)初始化
首先有三种方式来初始化:
- 1
默认的构造器,将会以默认的大小来初始化内部的数组
- 1
用一个ICollection对象来构造,并将该集合的元素添加到ArrayList
- 1
用指定的大小来初始化内部的数组
后两种方式都可以理解,通过创造对象,或指定大小来初始化内部数据即可。
那我们来重点关注一下无参数构造器的实现过程:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
可以看出它的默认数组为长度为0。而在之前JDK1,6中,无参数构造器代码是初始长度为10。
JDK6代码这样的:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
接下来,要扩容的话,肯定是在ArrayList.add 方法中。我们来看一下具体实现。
二)确保内部容量
我们以无参数构造为例,
初始化时,数组长度为0.
那我现在要添加数据了,数组的长度是怎么变化的?
- 1
- 2
- 3
- 4
- 5
- 6
① ensureCapacityInternal方法名的英文大致是“确保内部容量”,size表示的是执行添加之前的元素个数,并非ArrayList的容量,容量应该是数组elementData的长度。ensureCapacityInternal该方法通过将现有的元素个数数组的容量比较。看如果需要扩容,则扩容。
②是将要添加的元素放置到相应的数组中。
下面具体看 ensureCapacityInternal(size + 1); // ① 是如何判断和扩容的。
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
以上,elementData是用来存储实际内容的数组。minExpand 是最小扩充容量。
DEFAULTCAPACITY_EMPTY_ELEMENTDATA共享的空数组实例用于默认大小的空实例。根据传入的最小需要容量minCapacity来和数组的容量长度对比,若minCapactity大于或等于数组容量,则需要进行扩容。
三)扩容
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
综上,ArrayList相当于在没指定initialCapacity时就是会使用延迟分配对象数组空间,当第一次插入元素时才分配10(默认)个对象空间。假如有20个数据需要添加,那么会分别在第一次的时候,将ArrayList的容量变为10 (如下图一);之后扩容会按照1.5倍增长。也就是当添加第11个数据的时候,Arraylist继续扩容变为10*1.5=15(如下图二);当添加第16个数据时,继续扩容变为15 * 1.5 =22个(如下图四)。:
向数组中添加第一个元素时,数组容量为10.
向数组中添加到第10个元素时,数组容量仍为10.
向数组中添加到第11个元素时,数组容量扩为15.
向数组中添加到第16个元素时,数组容量扩为22.
每次扩容都是通过Arrays.copyOf(elementData, newCapacity) 这样的方式实现的。
对比和总结:
本文介绍了 ArrayList动态扩容的全过程。如果通过无参构造的话,初始数组容量为0,当真正对数组进行添加时,才真正分配容量。每次按照1.5倍(位运算)的比率通过copeOf的方式扩容。 在JKD1.6中实现是,如果通过无参构造的话,初始数组容量为10.每次通过copeOf的方式扩容后容量为原来的1.5倍加1.以上就是动态扩容的原理。明白了这些以后,当我们已经确定了要插入的对象的大致数目在创建前就使用有参构造才是明智之选。
- ArrayList应用
- arraylist的应用
- ArrayList 应用(C#)
- arrayList的应用
- ArrayList详解应用
- ArrayList的应用
- C#ArrayList简单应用
- ArrayList应用举例
- C#ArrayList简单应用
- C#ArrayList简单应用
- Java Arraylist应用
- java ArrayList的应用
- ArrayList 集合的应用
- ArrayList的实际应用
- vb.net中应用 ArrayList
- java基础应用之ArrayList
- VB.Net--应用ArrayList实例
- java中ArrayList应用实例
- springboot学习笔记(二) Thymeleaf
- 创建一个数据库
- 云平台快速部署与源码编译lamp应用wordpress
- 优秀工程师-UIViewController
- Electron项目打包
- ArrayList应用
- insertion-sort-list java code
- ERROR: org.apache.hadoop.hbase.PleaseHoldException: Master is initializing
- springboot学习笔记(三) Restful API
- SQLSERVER多表联查,多表分页查询
- 1.7 Web的结构组件
- ElasticSearch中don't run elasticsearch as root
- 深入理解Laravel框架--手动创建laravel框架(1)
- 每周 Bugs 10.9-10.15