LinkedBlockingDeque的源码解析(基于JDK1.8)

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: LinkedBlockingDeque的源码解析(基于JDK1.8)LinkedBlockingDeque是Java中的一个阻塞双端队列,它继承自AbstractQueue类并实现了BlockingDeque接口。在多线程环境下,LinkedBlockingDeque能够提供高效的并发访问能力。下面我们来看一下它的源码实现。

LinkedBlockingDeque的源码解析(基于JDK1.8)

LinkedBlockingDeque是Java中的一个阻塞双端队列,它继承自AbstractQueue类并实现了BlockingDeque接口。在多线程环境下,LinkedBlockingDeque能够提供高效的并发访问能力。下面我们来看一下它的源码实现。


数据结构

LinkedBlockingDeque是基于链表实现的双向队列。它的每一个节点都包含了一个元素以及指向前后节点的两个指针,它的头节点和尾节点都是空节点(null)。


构造函数

LinkedBlockingDeque提供了三个构造函数:


public LinkedBlockingDeque(): 默认构造函数,创建一个初始容量为Integer.MAX_VALUE的双向队列;

public LinkedBlockingDeque(int capacity): 创建一个指定容量的双向队列;

public LinkedBlockingDeque(Collection<? extends E> c): 创建一个包含指定集合元素的双向队列,元素按照集合迭代器返回的顺序排列。

插入操作

LinkedBlockingDeque提供了以下插入操作,当队列已满时,这些操作会阻塞当前线程,直到队列中有空间可用。


public void addFirst(E e): 将元素插入到队列头部;

public void addLast(E e): 将元素插入到队列尾部;

public boolean offerFirst(E e): 尝试将元素插入到队列头部,如果队列已满则返回false,插入成功则返回true;

public boolean offerLast(E e): 尝试将元素插入到队列尾部,如果队列已满则返回false,插入成功则返回true;

public void putFirst(E e) throws InterruptedException: 将元素插入到队列头部,如果队列已满则阻塞当前线程,直到队列有空间可用;

public void putLast(E e) throws InterruptedException: 将元素插入到队列尾部,如果队列已满则阻塞当前线程,直到队列有空间可用。

移除操作

LinkedBlockingDeque提供了以下移除操作,当队列为空时,这些操作会阻塞当前线程,直到队列中有元素可供移除。


public E removeFirst(): 移除并返回队列头部的元素,如果队列为空则抛出NoSuchElementException异常;

public E removeLast(): 移除并返回队列尾部的元素,如果队列为空则抛出NoSuchElementException异常;

public E pollFirst(): 移除并返回队列头部的元素,如果队列为空则返回null;

public E pollLast(): 移除并返回队列尾部的元素,如果队列为空则返回null;

public E takeFirst() throws InterruptedException: 移除并返回队列头部的元素,如果队列为空则阻塞当前线程,直到队列中有元素可供移除;

public E takeLast() throws InterruptedException: 移除并返回队列尾部的元素,如果队列为空则阻塞当前线程,直到队列中有元素可供移除。

检索操作

LinkedBlockingDeque提供了以下检索操作,当队列为空时,这些操作会阻塞当前线程,直到队列中有元素可供检索。


public E getFirst(): 返回队列头部的元素,如果队列为空则抛出NoSuchElementException异常;

public E getLast(): 返回队列尾部的元素,如果队列为空则抛出NoSuchElementException异常;

public E peekFirst(): 返回队列头部的元素,如果队列为空则返回null;

public E peekLast(): 返回队列尾部的元素,如果队列为空则返回null。

其它操作

LinkedBlockingDeque还提供了以下其它操作:


public int size(): 返回队列中元素的数量;

public int remainingCapacity(): 返回队列中剩余空间的数量;

public boolean removeFirstOccurrence(Object o): 移除队列中第一个等于指定元素的元素,如果移除成功则返回true,否则返回false;

public boolean removeLastOccurrence(Object o): 移除队列中最后一个等于指定元素的元素,如果移除成功则返回true,否则返回false;

public Object[] toArray(): 返回包含队列所有元素的数组,元素按照从头到尾的顺序排列;

public <T> T[] toArray(T[] a): 返回包含队列所有元素的数组,元素按照从头到尾的顺序排列,如果指定数组a的长度不足以容纳队列中所有元素,则会创建一个新数组并返回。

总结

LinkedBlockingDeque是一个高效的双向队列,能够提供高并发的访问能力。我们可以通过它提供的各种插入、移除、检索和其它操作来满足不同的业务需求。

相关文章
|
10天前
|
存储 设计模式 算法
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
行为型模式用于描述程序在运行时复杂的流程控制,即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务,它涉及算法与对象间职责的分配。行为型模式分为类行为模式和对象行为模式,前者采用继承机制来在类间分派行为,后者采用组合或聚合在对象间分配行为。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象行为模式比类行为模式具有更大的灵活性。 行为型模式分为: • 模板方法模式 • 策略模式 • 命令模式 • 职责链模式 • 状态模式 • 观察者模式 • 中介者模式 • 迭代器模式 • 访问者模式 • 备忘录模式 • 解释器模式
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
|
10天前
|
设计模式 存储 安全
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
结构型模式描述如何将类或对象按某种布局组成更大的结构。它分为类结构型模式和对象结构型模式,前者采用继承机制来组织接口和类,后者釆用组合或聚合来组合对象。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象结构型模式比类结构型模式具有更大的灵活性。 结构型模式分为以下 7 种: • 代理模式 • 适配器模式 • 装饰者模式 • 桥接模式 • 外观模式 • 组合模式 • 享元模式
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
|
10天前
|
设计模式 存储 安全
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
创建型模式的主要关注点是“怎样创建对象?”,它的主要特点是"将对象的创建与使用分离”。这样可以降低系统的耦合度,使用者不需要关注对象的创建细节。创建型模式分为5种:单例模式、工厂方法模式抽象工厂式、原型模式、建造者模式。
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
|
2月前
|
缓存 监控 Java
Java线程池提交任务流程底层源码与源码解析
【11月更文挑战第30天】嘿,各位技术爱好者们,今天咱们来聊聊Java线程池提交任务的底层源码与源码解析。作为一个资深的Java开发者,我相信你一定对线程池并不陌生。线程池作为并发编程中的一大利器,其重要性不言而喻。今天,我将以对话的方式,带你一步步深入线程池的奥秘,从概述到功能点,再到背景和业务点,最后到底层原理和示例,让你对线程池有一个全新的认识。
57 12
|
29天前
|
PyTorch Shell API
Ascend Extension for PyTorch的源码解析
本文介绍了Ascend对PyTorch代码的适配过程,包括源码下载、编译步骤及常见问题,详细解析了torch-npu编译后的文件结构和三种实现昇腾NPU算子调用的方式:通过torch的register方式、定义算子方式和API重定向映射方式。这对于开发者理解和使用Ascend平台上的PyTorch具有重要指导意义。
|
11天前
|
安全 搜索推荐 数据挖掘
陪玩系统源码开发流程解析,成品陪玩系统源码的优点
我们自主开发的多客陪玩系统源码,整合了市面上主流陪玩APP功能,支持二次开发。该系统适用于线上游戏陪玩、语音视频聊天、心理咨询等场景,提供用户注册管理、陪玩者资料库、预约匹配、实时通讯、支付结算、安全隐私保护、客户服务及数据分析等功能,打造综合性社交平台。随着互联网技术发展,陪玩系统正成为游戏爱好者的新宠,改变游戏体验并带来新的商业模式。
|
2月前
|
Java 编译器 API
深入解析:JDK与JVM的区别及联系
在Java开发和运行环境中,JDK(Java Development Kit)和JVM(Java Virtual Machine)是两个核心概念,它们在Java程序的开发、编译和运行过程中扮演着不同的角色。本文将深入解析JDK与JVM的区别及其内在联系,为Java开发者提供清晰的技术干货。
37 1
|
4月前
|
Java
安装JDK18没有JRE环境的解决办法
安装JDK18没有JRE环境的解决办法
396 3
|
10天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
111 7
|
5月前
|
Java 关系型数据库 MySQL
"解锁Java Web传奇之旅:从JDK1.8到Tomcat,再到MariaDB,一场跨越数据库的冒险安装盛宴,挑战你的技术极限!"
【8月更文挑战第19天】在Linux上搭建Java Web应用环境,需安装JDK 1.8、Tomcat及MariaDB。本指南详述了使用apt-get安装OpenJDK 1.8的方法,并验证其版本。接着下载与解压Tomcat至`/usr/local/`目录,并启动服务。最后,通过apt-get安装MariaDB,设置基本安全配置。完成这些步骤后,即可验证各组件的状态,为部署Java Web应用打下基础。
66 1

推荐镜像

更多