【面试题精讲】ArrayDeque 与 LinkedList 的区别

简介: 【面试题精讲】ArrayDeque 与 LinkedList 的区别

有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准https://blog.zysicyj.top

首发博客地址

面试题手册

系列文章地址


1. 什么是ArrayDeque和LinkedList?

  • ArrayDeque:ArrayDeque是Java集合框架中的一个双端队列(deque)实现类。它基于数组实现,可以在两端高效地插入和删除元素。
  • LinkedList:LinkedList也是Java集合框架中的一个双端队列实现类。它基于链表实现,可以在任意位置高效地插入和删除元素。

2. 为什么需要ArrayDeque和LinkedList?

  • ArrayDeque:由于ArrayDeque底层使用数组实现,因此在随机访问元素时具有较好的性能。同时,ArrayDeque还提供了一些特殊方法,如栈操作(push/pop)和队列操作(offer/poll),使得它非常适用于需要高效插入和删除元素的场景。
  • LinkedList:LinkedList底层使用链表实现,因此在插入和删除元素时具有较好的性能。而且,LinkedList还提供了一些特殊方法,如addFirst/addLast/removeFirst/removeLast等,使得它非常适用于需要频繁在头部或尾部进行插入和删除操作的场景。

3. ArrayDeque和LinkedList的实现原理?

ArrayDeque:

  • ArrayDeque内部维护了一个循环数组,通过两个指针(front和rear)来标记队列的头部和尾部。当向队列中添加元素时,rear指针向后移动;当从队列中删除元素时,front指针向后移动。如果数组满了,ArrayDeque会自动扩容。
  • ArrayDeque的底层数组长度是2的幂次方,这样可以通过位运算来实现循环队列的操作,提高性能。

LinkedList:

  • LinkedList内部使用双向链表来存储元素。每个节点都包含一个前驱节点和一个后继节点的引用。通过这种方式,LinkedList可以在任意位置高效地插入和删除元素。
  • LinkedList还有一个头结点和尾节点的引用,分别表示链表的头部和尾部。通过这两个引用,可以快速访问到链表的第一个和最后一个元素。

4. ArrayDeque和LinkedList的使用示例

ArrayDeque示例:

import java.util.ArrayDeque;
public class ArrayDequeExample {
    public static void main(String[] args) {
        ArrayDeque<Integer> deque = new ArrayDeque<>();
        // 添加元素
        deque.addFirst(1);
        deque.addLast(2);
        // 获取元素
        int first = deque.getFirst();
        int last = deque.getLast();
        System.out.println("First element: " + first); // 输出:First element: 1
        System.out.println("Last element: " + last); // 输出:Last element: 2
        // 删除元素
        deque.removeFirst();
        deque.removeLast();
        System.out.println("Size: " + deque.size()); // 输出:Size: 0
    }
}

LinkedList示例:

import java.util.LinkedList;
public class LinkedListExample {
    public static void main(String[] args) {
        LinkedList<Integer> list = new LinkedList<>();
        // 添加元素
        list.addFirst(1);
        list.addLast(2);
        // 获取元素
        int first = list.getFirst();
        int last = list.getLast();
        System.out.println("First element: " + first); // 输出:First element: 1
        System.out.println("Last element: " + last); // 输出:Last element: 2
        // 删除元素
        list.removeFirst();
        list.removeLast();
        System.out.println("Size: " + list.size()); // 输出:Size: 0
    }
}

5. ArrayDeque和LinkedList的优点

ArrayDeque的优点:

  • 随机访问元素时具有较好的性能,时间复杂度为O(1)。
  • 支持栈操作(push/pop)和队列操作(offer/poll),非常灵活。

LinkedList的优点:

  • 在任意位置插入和删除元素时具有较好的性能,时间复杂度为O(1)。
  • 提供了一些特殊方法(addFirst/addLast/removeFirst/removeLast等),方便在头部或尾部进行操作。

6. ArrayDeque和LinkedList的缺点

ArrayDeque的缺点:

  • 不支持线程安全,如果需要在多线程环境下使用,需要额外考虑同步问题。

LinkedList的缺点:

  • 访问指定位置的元素时性能较差,时间复杂度为O(n)。
  • 占用的内存空间相对较大,因为每个节点都需要额外的指针来维护链表结构。

7. ArrayDeque和LinkedList的使用注意事项

ArrayDeque的注意事项:

  • 不支持null元素,如果添加了null元素会抛出NullPointerException异常。

LinkedList的注意事项:

  • 在频繁插入和删除元素时,尽量避免在中间位置进行操作,因为这样会导致性能下降。

8. 总结

ArrayDeque和LinkedList是Java集合框架中的两种双端队列实现类。它们分别基于数组和链表实现,在不同的场景下具有不同的优势。ArrayDeque适用于需要高效随机访问元素和栈/队列操作的场景,而LinkedList适用于需要频繁在头部或尾部进行插入和删除操作的场景。在选择使用哪种实现类时,可以根据具体的需求来决定。

本文由 mdnice 多平台发布

相关文章
|
18天前
|
Java 程序员
Java社招面试题:& 和 && 的区别,HR的套路险些让我翻车!
小米,29岁程序员,分享了一次面试经历,详细解析了Java中&和&&的区别及应用场景,展示了扎实的基础知识和良好的应变能力,最终成功获得Offer。
45 14
|
3月前
|
Android开发 Kotlin
Android经典面试题之Kotlin的==和===有什么区别?
本文介绍了 Kotlin 中 `==` 和 `===` 操作符的区别:`==` 用于比较值是否相等,而 `===` 用于检查对象身份。对于基本类型,两者行为相似;对于对象引用,`==` 比较值相等性,`===` 检查引用是否指向同一实例。此外,还列举了其他常用比较操作符及其应用场景。
193 93
|
16天前
|
Java 关系型数据库 数据库
京东面试:聊聊Spring事务?Spring事务的10种失效场景?加入型传播和嵌套型传播有什么区别?
45岁老架构师尼恩分享了Spring事务的核心知识点,包括事务的两种管理方式(编程式和声明式)、@Transactional注解的五大属性(transactionManager、propagation、isolation、timeout、readOnly、rollbackFor)、事务的七种传播行为、事务隔离级别及其与数据库隔离级别的关系,以及Spring事务的10种失效场景。尼恩还强调了面试中如何给出高质量答案,推荐阅读《尼恩Java面试宝典PDF》以提升面试表现。更多技术资料可在公众号【技术自由圈】获取。
|
1月前
|
存储 缓存 网络协议
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点,GET、POST的区别,Cookie与Session
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点、状态码、报文格式,GET、POST的区别,DNS的解析过程、数字证书、Cookie与Session,对称加密和非对称加密
|
2月前
|
编译器
经典面试题:变量的声明和定义有什么区别
在编程领域,变量的“声明”与“定义”是经典面试题之一。声明告诉编译器一个变量的存在,但不分配内存,通常包含变量类型和名称;而定义则为变量分配内存空间,一个变量必须至少被定义一次。简而言之,声明是告知变量形式,定义则是实际创建变量并准备使用。
|
2月前
|
XML 前端开发 Java
Spring,SpringBoot和SpringMVC的关系以及区别 —— 超准确,可当面试题!!!也可供零基础学习
本文阐述了Spring、Spring Boot和Spring MVC的关系与区别,指出Spring是一个轻量级、一站式、模块化的应用程序开发框架,Spring MVC是Spring的一个子框架,专注于Web应用和网络接口开发,而Spring Boot则是对Spring的封装,用于简化Spring应用的开发。
169 0
Spring,SpringBoot和SpringMVC的关系以及区别 —— 超准确,可当面试题!!!也可供零基础学习
|
2月前
|
前端开发 小程序 JavaScript
面试官:px、em、rem、vw、rpx 之间有什么区别?
面试官:px、em、rem、vw、rpx 之间有什么区别?
58 0
|
3月前
|
Java 关系型数据库 MySQL
面试官:GROUP BY和DISTINCT有什么区别?
面试官:GROUP BY和DISTINCT有什么区别?
100 0
面试官:GROUP BY和DISTINCT有什么区别?
|
4月前
|
算法 Java
【多线程面试题十八】、说一说Java中乐观锁和悲观锁的区别
这篇文章讨论了Java中的乐观锁和悲观锁的区别,其中悲观锁假设最坏情况并在访问数据时上锁,如通过`synchronized`或`Lock`接口实现;而乐观锁则在更新数据时检查是否被其他线程修改,适用于多读场景,并常通过CAS操作实现,如Java并发包`java.util.concurrent`中的类。
|
4月前
|
Java
【多线程面试题十三】、说一说synchronized与Lock的区别
这篇文章讨论了Java中`synchronized`和`Lock`接口在多线程编程中的区别,包括它们在实现、使用、锁的释放、超时设置、锁状态查询以及锁的属性等方面的不同点。