LinkedList使用详解

简介: LinkedList使用详解

概述


LinkedList是一个功能十分强大的集合,看它的名字可能误以为只有List顺序容器的功能,实际上它还可以作为一个双端队列,也可以作为一个栈来使用。那么我们以java8版本来对LinkedList做一个功能讲解和使用体验。


功能介绍


1671174520077.jpg

LinkedList底层的数据结构是双向的链表。

特点:

  • 底层数据结果是双向链表,插入删除速度快,查找速度慢。
  • LinkedList可以作为一个顺序容器使用
  • LInkedList可以作为一个队列使用,元素先进先出
  • LinkedList可以作为一个栈使用, 元素先进后出
  • 允许放入null元素
  • 不是线程安全,并发修改的时候会抛出ConcurrentModificationException异常


构造方法


  1. LinkedList()

说明:构造一个空容器

  1. LinkedList(Collection<? extends E> c)

说明:构造一个内容为入参容器c的的容器。


有序列表相关方法


  1. boolean add(E e)

说明: 向集合中添加元素

  1. void add(int index, E element)

说明: 向集合指定位置后面添加一个元素

  1. boolean addAll(Collection<? extends E> c)

说明: 向集合中添加另外一个集合的元素

  1. boolean addAll(int index, Collection<? extends E> c)

说明: 向集合指定位置后面添加另外一个集合的全部元素

  1. E set(int index, E element)

说明: 设置集合中某个位置元素的值,返回修改前的内容

  1. boolean remove(Object o)

说明:删除集合中碰到的第一和o一样的元素,如果集合发生变化返回true

  1. E remove(int index)

说明:删除集合中某个位置的元素,返回删除的元素内容

  1. boolean removeAll(Collection<?> c)

说明:根据入参的集合,删除集合里面一样的元素,如果集合发生变化,返回true

  1. void clear()

说明:清空集合中的元素

  1. int size()

说明:返回容器中元素的数量

  1. boolean isEmpty()

说明:返回容器是否是空的,如果是空,返回true

  1. boolean contains(Object o)

说明:返回容器是否包含指定对象

  1. E get(int index)

说明:获取指定索引位置的元素

  1. int indexOf(Object o)

说明:从头部开始找,获取查找到指定元素的第一个索引位置, 如果返回-1表示没有找到


队列相关方法


  1. boolean offer(E e)

说明:队列中添加元素,往队列尾部添加元素

  1. E poll()

说明:从队列中获取元素,拿到的是最先放进去的,也就是头部的元素

  1. boolean offerFirst(E e)

说明:队列头部添加元素。

  1. boolean offerLast(E e)

说明:队列尾部添加元素

  1. E pollFirst()

说明:队列头部获取元素

  1. E pollLast()

说明:队列尾部获取元素


栈相关方法


  1. void push(E e)

说明:向栈中压入元素,也就是头部添加元素

  1. E pop()

说明:从栈中获取元素,相当于从队列头部获取元素

  1. E peek()

说明:查看栈顶元素


使用案例和总结


有序列表的使用


@Test
    public void testListFunc() {
        List<String> userNames = new LinkedList<>();
        userNames.add("alvin");
        userNames.add("cxw");
        userNames.add("hh");
        userNames.add("ss");
        String username = userNames.get(2);
        Assert.assertEquals("hh", username);
    }

小结:

ArrayList 是基于动态数组数据结构的实现,访问元素速度优于 LinkedList。LinkedList 是基于链表数据结构的实现,占用的内存空间比较大,但在批量插入或删除数据时优于 ArrayList。

对于快速访问对象的需求,使用 ArrayList 实现执行效率上会比较好。需要频繁向集合中插入和删除元素时,使用 LinkedList 类比 ArrayList 类效果高。


队列的使用


@Test
    public void testQueueFunc() {
        Deque<String> userNames = new LinkedList<>();
        userNames.offer("alvin");
        userNames.offer("cxw");
        userNames.offer("kk");
        String username = userNames.poll();
        Assert.assertEquals("alvin", username);
    }

小结: LinkedList可以支持队列的功能,底层通过队列实现,同样还有一个类ArrayDeque也支持,底层通过数组实现,通常情况下,ArrayDeque的性能和内存开销更优。


栈的使用


@Test
    public void testStackFunc() {
        Deque<String> userNames = new LinkedList<>();
        userNames.push("alvin");
        userNames.push("cxw");
        userNames.push("kk");
        String username = userNames.peek();
        Assert.assertEquals("kk", username);
        username = userNames.pop();
        Assert.assertEquals("kk", username);
    }

小结: java中有个有Stack的类支持栈的功能,它是线程安全的,性能查,不推荐使用。LinkedList可以栈的功能,底层通过队列实现,同样还有一个类ArrayDeque也支持,底层通过数组实现,通常情况下,ArrayDeque的性能和内存开销更优。


使用注意事项


  1. LinkedList底层采用双向队列实现,不需要进行扩容操作,在频繁插入和删除的场景性能更佳。
  2. 在 subList 场景中,高度注意对父集合元素的增加或删除,均会导致子列表的遍历、增加、删除产生 ConcurrentModificationException 异常。 说明:抽查表明,90% 的程序员对此知识点都有错误的认知。
  3. 使用集合转数组的方法,必须使用集合的 toArray(T[] array),传入的是类型完全一致、长度为0 的空数组。
  4. 使用 Collection 接口任何实现类的 addAll() 方法时,要对输入的集合参数进行 NPE 判断。

说明:在 ArrayList#addAll 方法的第一行代码即 Object[] a = c.toArray();其中 c 为输入集合参数,如果为 null,则直接抛出异常。

  1. 不要在 foreach 循环里进行元素的 remove / add 操作。remove 元素请使用 iterator 方式,如果并发操作,需要对 iterator 对象加锁。
  2. 使用工具类 Arrays.asList() 把数组转换成集合时,不能使用其修改集合相关的方法,它的 add/ remove / clear 方法会抛出 UnsupportedOperationException 异常。
  3. Collections 类返回的对象,如:emptyList() / singletonList() 等都是 immutable list,不可

对其进行添加或者删除元素的操作。

目录
相关文章
|
7月前
|
存储 安全 Java
ArrayList vs. LinkedList: Java集合框架的比较与应用
ArrayList vs. LinkedList: Java集合框架的比较与应用
|
28天前
|
索引
ArrayList和LinkedList的区别
ArratList的底层使用动态数组,默认容量为10,当元素数量到达容量时,生成一个新的数组,大小为前一次的1.5倍,然后将原来的数组copy过来; 因为数组有索引,所以ArrayList查找数据更快,但是添加数据效率更低 LinkedList的底层使用链表,在内存中是离散的,没有扩容机制;LinkedList在查找数据时需要从头遍历,所以查找慢,但是添加数据效率更高
|
1月前
LinkedList
LinkedList 是一个基于双向链表实现的集合类,经常被拿来和 ArrayList 做比较。 实现了以下接口: List : 表明它是一个列表,支持添加、删除、查找等操作,并且可以通过下标进行访问。 Deque :继承自 Queue 接口,具有双端队列的特性,支持从两端插入和删除元素,方便实现栈和队列等数据结构。需要注意,Deque 的发音为 "deck" [dɛk],这个大部分人都会读错。 Cloneable :表明它具有拷贝能力,可以进行深拷贝或浅拷贝操作。 Serializable : 表明它可以进行序列化操作,也就是可以将对象转换为字节流进行持久
|
4月前
LinkedList的使用
LinkedList的使用
34 2
|
6月前
|
存储 Java 容器
【JAVA集合篇 - LinkedList】你真的了解LinkedList吗?
【JAVA集合篇 - LinkedList】你真的了解LinkedList吗?
45 0
|
安全
ArrayList 和 LinkedList 的区别【重要】
ArrayList 和 LinkedList 的区别【重要】
73 0
|
7月前
|
存储 安全
ArrayList 和 LinkedList 的区别
ArrayList 和 LinkedList 的区别
|
存储 设计模式 算法
ArrayList和LinkedList
介绍ArrayList和LinkedList
|
存储 算法
ArrayList与LinkedList的比较
在做ArrayList与LinkedList的比较之前,必须先对这两个数据结构有一定的学习和掌握,之前2篇文章分别讲了ArrayList与LinkedList的介绍和源码讲解
141 0
ArrayList与LinkedList的比较
|
存储 Java 索引
17. 什么情况用ArrayList or LinkedList呢?
17. 什么情况用ArrayList or LinkedList呢?
116 0
17. 什么情况用ArrayList or LinkedList呢?

热门文章

最新文章