jdk8源码之Queue-ArrayQueue

ArrayQueue是Java中一种基于数组实现的先进先出(FIFO)队列,常作为缓冲队列使用。本文详细介绍了ArrayQueue的初始化、offer、poll、peek、remove、add、push和spliterator等操作的源码实现,分析了其内部结构和扩容机制。此外,还探讨了ArrayQueue在数据结构变更时与快速失败策略的区别以及可能的使用场景。
摘要由CSDN通过智能技术生成

关于队列这个数据结构,大家应该都是比较熟悉。列队是一种先进先出(FIFO)的数据结构。删除操作只能在表的头部,插入操作只能在表的尾部。
Queue一般是作为一个缓冲队列使用的,简单举例:生产端的生产速度偶尔会大于消费端的消费速度,但又不想等待对方,此时如果有个缓存队列这样的问题就解决啦。生产端生产的东西只管放入缓存队列,消费端从缓存队列里面拿东西,达到一个缓冲的目的。
图片描述
LinkedList是基于链表来实现,ArrayQueue基于数组实现。下面我们会主要讲一下这ArrayQueue者的源码实现。

ArrayQueue

public class ArrayDeque<E> extends AbstractCollection<E>
                           implements Deque<E>, Cloneable, Serializable
{
   
 //实际存放元素的数组
 transient Object[] elements; 
 //头指针
 transient int head;
 //尾指针
 transient int tail;
 //默认最小容量
 private static final int MIN_INITIAL_CAPACITY = 8;

 }
ArrayQueue初始化
//未制定容量时,默认为16
public ArrayDeque() {
        elements = new Object[16];
    }
//制定初始容量
public ArrayDeque(int numElements) {
        allocateElements(numElements);
    }
//指定初始值
public ArrayDeque(Collection<? extends E> c) {
        allocateElements(c.size());
        addAll(c);
    }
//指定容量小于8时,返回8
//否则,返回initialCapacity=2^n,2^n越界时,则取2^30
private void allocateElements(int numElements) {
        int initialCapacity = MIN_INITIAL_CAPACITY;
        if (numElements >= initialCapacity) {
            initialCapacity = numElements;
            initialCapacity |= (initialCapacity >>>  1);
            initialCapacity |= (initialCapacity >>>  2);
            initialCapacity |= (initialCapacity >>>  4);
            initialCapacity |= (initialCapacity >>>  8);
            initialCapacity |= (initialCapacity >>> 16);
            initialCapacity++;

            
JDK-8u381-linux是Java Development Kit (JDK) 的一个版本,用于在Linux操作系统下开发和运行Java应用程序。JDK是一个软件开发工具包,它提供了开发人员所需的工具、运行时环境和相关文档,以便他们可以创建和部署Java应用程序。 JDK-8u381-linux是JDK的第8个主要版本,并且更新到了第381个更新版本。这个版本是Java 8的一个补丁版本,它修复了之前版本中的一些bug和安全漏洞。更新版本的目的是提供更稳定和安全的Java运行环境,以保证应用程序的正常运行。 使用JDK-8u381-linux,开发人员可以使用Java编程语言创建各种类型的应用程序,包括桌面应用程序、Web应用程序、企业级应用程序和移动应用程序等。JDK提供了编译器、调试器、运行时环境和其他必要的工具,使得开发人员能够高效地编写和调试Java代码。 在Linux操作系统上安装JDK-8u381-linux非常简单。首先,需要从Oracle官方网站下载JDK-8u381-linux的安装包。然后,打开终端,并使用命令行工具解压安装包。接下来,设置JAVA_HOME环境变量,以便系统可以找到安装的JDK。最后,验证安装是否成功,可以使用命令行工具运行java -version命令来检查安装的JDK版本。 总而言之,JDK-8u381-linux是一个用于在Linux操作系统下开发和运行Java应用程序的软件开发工具包。它提供了必要的工具和运行时环境,以便开发人员能够高效地创建和部署Java应用程序。通过安装和使用JDK-8u381-linux,开发人员可以利用Java的强大功能来构建各种类型的应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值