List集合的实现类

简介: List集合的实现类

List集合的实现类

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

  • ArrayList集合
    底层是数组结构实现,查询快、增删慢
  • LinkedList集合
    底层是链表结构实现,查询慢、增删快

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

  • 特有方法
方法名 说明
public void addFirst(E e) 在该列表开头插入指定的元素
public void addLast(E e) 将指定的元素追加到此列表的末尾
public E getFirst() 返回此列表中的第一个元素
public E getLast() 返回此列表中的最后一个元素
public E removeFirst() 从此列表中删除并返回第一个元素
public E removeLast() 从此列表中删除并返回最后一个元素
  • 示例代码

public class MyLinkedListDemo4 {

   public static void main(String[] args) {

       LinkedList<String> list = new LinkedList<>();

       list.add("aaa");

       list.add("bbb");

       list.add("ccc");

//        public void addFirst(E e) 在该列表开头插入指定的元素

       //method1(list);

//        public void addLast(E e)  将指定的元素追加到此列表的末尾

       //method2(list);

//        public E getFirst()       返回此列表中的第一个元素

//        public E getLast()        返回此列表中的最后一个元素

       //method3(list);

//        public E removeFirst()        从此列表中删除并返回第一个元素

//        public E removeLast()     从此列表中删除并返回最后一个元素

       //method4(list);

     

   }

   private static void method4(LinkedList<String> list) {

       String first = list.removeFirst();

       System.out.println(first);

       String last = list.removeLast();

       System.out.println(last);

       System.out.println(list);

   }

   private static void method3(LinkedList<String> list) {

       String first = list.getFirst();

       String last = list.getLast();

       System.out.println(first);

       System.out.println(last);

   }

   private static void method2(LinkedList<String> list) {

       list.addLast("www");

       System.out.println(list);

   }

   private static void method1(LinkedList<String> list) {

       list.addFirst("qqq");

       System.out.println(list);

   }

}

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 迭代器源码分析:

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

  • Iterator<E> iterator()  :获取一个迭代器对象
  • boolean hasNext()       :判断当前指向的位置是否有元素
  • E next()                :获取当前指向的元素并移动指针

迭代器源码分析


相关文章
|
4月前
|
存储 安全 Java
【Java集合类面试二十五】、有哪些线程安全的List?
线程安全的List包括Vector、Collections.SynchronizedList和CopyOnWriteArrayList,其中CopyOnWriteArrayList通过复制底层数组实现写操作,提供了最优的线程安全性能。
|
4月前
|
安全
List集合特有功能
List集合特有功能
42 2
|
4月前
|
Java
【Java集合类面试二十三】、List和Set有什么区别?
List和Set的主要区别在于List是一个有序且允许元素重复的集合,而Set是一个无序且元素不重复的集合。
|
4月前
|
存储 Java
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
|
4月前
|
编译器
【Bug记录】list模拟实现const迭代器类
【Bug记录】list模拟实现const迭代器类
|
2月前
|
安全 Java 程序员
深入Java集合框架:解密List的Fail-Fast与Fail-Safe机制
本文介绍了 Java 中 List 的遍历和删除操作,重点讨论了快速失败(fail-fast)和安全失败(fail-safe)机制。通过普通 for 循环、迭代器和 foreach 循环的对比,详细解释了各种方法的优缺点及适用场景,特别是在多线程环境下的表现。最后推荐了适合高并发场景的 fail-safe 容器,如 CopyOnWriteArrayList 和 ConcurrentHashMap。
68 5
|
1月前
|
NoSQL Java Redis
List集合按照由小到大排序或者由大到小排序
List集合按照由小到大排序或者由大到小排序
45 0
|
2月前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
29 3
|
3月前
|
NoSQL Java Redis
List集合按照由小到大排序或者由大到小排序
List集合按照由小到大排序或者由大到小排序
26 3
|
4月前
|
存储 安全 Java
java集合框架复习----(2)List
这篇文章是关于Java集合框架中List集合的详细复习,包括List的特点、常用方法、迭代器的使用,以及ArrayList、Vector和LinkedList三种实现类的比较和泛型在Java中的使用示例。
java集合框架复习----(2)List