历史文章: Collection 源码分析 AbstractList 源码分析 介绍 ArrayList是一个数组队列,相当于动态数组,与Java的数组对比,他的容量可以动态改变. 继承关系 ArrayList继承AbstractList 实现了List,RandomAccess,Cloneable,Serializable接口 特点 基于数组实现速度快 实现了RandomAccess接口,提供了随机访问功能 实现了Cloneable接口,能被克隆 实现了Serializable接口,支持序列化…
java基础 之 list源码分析(ArrayList) ArrayList: 继承关系分析: public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable 我们可以知道: 继承了AbstractList 实现了List接口 实现了RandomAccess,这里举例说明下这个接口的作用,我们看一段代码:…
[集合框架]JDK1.8源码分析之ArrayList详解(一) 一. 从ArrayList字表面推测 ArrayList类的命名是由Array和List单词组合而成,Array的中文意思是数组,List的中文意思是列表.从ArrayList字表面推测,ArrayList类是否有数组和列表的特征?那么,这些特征这在ArrayList类中又是怎么体现的? ArrayList源码分析 public class ArrayList<E> extends AbstractList<E> im…
1.概述 LinkedHashMap继承自HashMap:在HashMap基础上,通过维护一条双向链表,解决了HashMap键值对遍历顺序和插入顺序一致的问题. 想了解LinkedHashMap源码,首先需要了解HashMap源码. 2.原理 3.源码分析 结合我的<源码分析(1)-HashMap(JDK1.8)>文章 https://www.cnblogs.com/wangymd/p/11750194.html. 3.1.成员属性 //双向联调头 transient LinkedHashMa…
一.前言 分析了Map中主要的类之后,下面我们来分析Collection下面几种常见的类,如ArrayList.LinkedList.HashSet.TreeSet等.下面通过JDK源码来一起分析ArrayList底层是如何实现的.(PS:把JVM看完了之后终于可以有成片的时间来阅读源码了,感觉简直不能更爽). 二.ArrayList数据结构 分析一个类的时候,数据结构往往是它的灵魂所在,理解底层的数据结构其实就理解了该类的实现思路,具体的实现细节再具体分析. ArrayList的数据结构如下:…
ArrayList简介 从上图可以看到,ArrayList是集合框架中List接口的一个实现类,它继承了AbstractList类,实现了List, RandomAccess, Cloneable, Serializable. 实现List接口,对数组的基本增删改查操作. 实现RandomAccess接口,快速随机访问功能. 实现Cloneable接口,可以被复制,clone()方法. 实现Serializable接口,支持序列化,可以序列化传输.保证类的一致. 在使用基本数组保存数据的时候,数…
一.类定义 public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable 二.属性 // 序列化id private static final long serialVersionUID = 8683452581122892189L; // 默认初始的容量 private static final in…
一.UML类图 ConcurrentHashMap键值不能为null:底层数据结构是数组+链表/红黑二叉树:采用CAS(比较并交换)和synchronized来保证并发安全. CAS文章:https://blog.csdn.net/v123411739/article/details/79561458 JDK1.7ConcurrentHashMap源码:https://www.cnblogs.com/chengxiao/p/6842045.html 二.源码分析 重要的成员变量: //数组,类似…
UML类图 java.util.Map<K, V>接口,有4个实现类:HashMap.Hashtable.LinkedHashMap和TreeMap. 1.说明 (1)HashMap除允许键值为null.非线程安全.使用散列存储方式存储键值,数据存储无序.如果想要使用有序存储可以使用LinkedHashMap.性能上当HashMap中保存的key的哈希算法能够均匀的分布在每个bucket(位桶)中的时候,HashMap在基本的get和set操作的的时间复杂度都是O(n).遍历HashMap的时…
一:首先看一下ArrayList类的结构体系: public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable 继承AbstractList抽象类,实现List接口.序列化接口等. 它的底层维护了一个Object[]数组,或者可以说它的底层数据结构是数组 /** * The array buffer in…