1.Collection集合

1.1数组和集合的区别【理解】

1.2集合类体系结构【理解】

01_集合类体系结构图

1.3Collection 集合概述和使用【应用】

1.4Collection集合的遍历

1.4.1 迭代器遍历

1.4.2 增强for

1.报错NoSuchElementException

2.迭代器遍历完毕,指针不会复位

3.循环中只能用一次next方法

4.迭代器遍历时,不能用集合的方法进行增加或者删除

1.4.3 lambda表达式

利用forEach方法,再结合lambda表达式的方式进行遍历

2.List集合

2.1List集合的概述和特点【记忆】

2.2List集合的特有方法【应用】

2.3List集合的五种遍历方式【应用】

  1. 迭代器
  2. 列表迭代器
  3. 增强for
  4. Lambda表达式
  5. 普通for循环

代码示例:

2.4 细节点注意:

List系列集合中的两个删除的方法

代码示例:

3.数据结构

3.1数据结构之栈和队列【记忆】

3.2数据结构之数组和链表【记忆】

4.List集合的实现类

4.1List集合子类的特点【记忆】

4.2LinkedList集合的特有功能【应用】

5. 源码分析

5.1 ArrayList源码分析:

核心步骤:

  1. 创建ArrayList对象的时候,他在底层先创建了一个长度为0的数组。

    数组名字:elementDate,定义变量size。

    size这个变量有两层含义: ①:元素的个数,也就是集合的长度 ②:下一个元素的存入位置

  2. 添加元素,添加完毕后,size++

扩容时机一:

  1. 当存满时候,会创建一个新的数组,新数组的长度,是原来的1.5倍,也就是长度为15.再把所有的元素,全拷贝到新数组中。如果继续添加数据,这个长度为15的数组也满了,那么下次还会继续扩容,还是1.5倍。

扩容时机二:

  1. 一次性添加多个数据,扩容1.5倍不够,怎么办呀?

    如果一次添加多个元素,1.5倍放不下,那么新创建数组的长度以实际为准。

举个例子: 在一开始,如果默认的长度为10的数组已经装满了,在装满的情况下,我一次性要添加100个数据很显然,10扩容1.5倍,变成15,还是不够,

怎么办?

此时新数组的长度,就以实际情况为准,就是110

具体分析过程可以参见视频讲解。

添加一个元素时的扩容:

第一次添加数据

添加多个元素时的扩容:

第11次添加数据

5.2 LinkedList源码分析:

底层是双向链表结构

核心步骤如下:

  1. 刚开始创建的时候,底层创建了两个变量:一个记录头结点first,一个记录尾结点last,默认为null
  2. 添加第一个元素时,底层创建一个结点对象,first和last都记录这个结点的地址值
  3. 添加第二个元素时,底层创建一个结点对象,第一个结点会记录第二个结点的地址值,last会记录新结点的地址值

具体分析过程可以参见视频讲解。

LinkedList源码分析

5.3 迭代器源码分析:

迭代器遍历相关的三个方法:

迭代器源码分析