java ArrayBlockingQueue源码探讨

java ArrayBlockingQueue源码探讨,第1张

java ArrayBlockingQueue源码探讨

在我们学习了ArrayBlockingQueue的基本内容后,需要进一步的对其源码进行探索,找出其中的一些方法,以及对用法的原理上有更深刻的理解。下面我们就ArrayBlockingQueue类的定义进行解析,找寻其参数、构造方法、同步机制的概念,进一步在其中分析源码。

1. 类的定义

public class ArrayBlockingQueue extends AbstractQueue
        implements BlockingQueue, java.io.Serializable

类的定义中可以看出

ArrayBlockingQueue是一个泛型类

ArrayBlockingQueue继承了AbstractQueue类,AbstractQueue是一个抽象类(模板方法)

ArrayBlockingQueue实现了BlockingQueue接口,表示一个阻塞队列

ArrayBlockingQueue实现了java.io.Serializable,表示支持序列化

2.参数

    final Object[] items;
 
    
    int takeIndex;
 
    
    int putIndex;
 
    
    int count;

3.构造方法

public ArrayBlockingQueue(int capacity) {
    this(capacity, false);
}
 
public ArrayBlockingQueue(int capacity, boolean fair) {
    if (capacity <= 0)
        throw new IllegalArgumentException();
    // 初始化数组
    this.items = new Object[capacity];
    // 创建重入锁及两个条件
    lock = new ReentrantLock(fair);
    notEmpty = lock.newCondition();
    notFull =  lock.newCondition();
}

通过构造方法我们可以得出以下两个结论:

(1)ArrayBlockingQueue初始化时必须传入容量,也就是数组的大小;

(2)可以通过构造方法控制重入锁的类型是公平锁还是非公平锁。

4.同步机制

以上就是关于java ArrayBlockingQueue源码的探讨,相信现在对于 ArrayBlockingQueue的使用和理解上都没有太多的问题。在接下来的文章中,会不断带来ArrayBlockingQueue的一些重要的方法。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/3017574.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-09-28
下一篇 2022-09-28

发表评论

登录后才能评论

评论列表(0条)

保存