jdk中的queue

本文从需求背景出发,探讨如何在并发环境下保证队列的顺序出队。深入分析了LinkedBlockingQueue的源码,重点讲解了其重要成员变量、插入方法(包括put和offer)以及读取方法(take、poll及其超时变种)。通过源码解析,揭示了该队列如何实现阻塞和线程安全特性。
摘要由CSDN通过智能技术生成

1- 需求背景

最近项目中有这样一个需求,因为在恢复WAL的过程中,以前是把WAL文件中的记录顺序的读出来,插入到阻塞队列(LinkedBlockingQueue)中,供消费端消费。后来发现顺序读取多个WAL文件插入队列的方式太慢,考虑使用并行WAL文件读取的方式,但是在插入队列时需要保证记录出队列时保持有序,于是考虑把LinkedBlockingQueue改成PriorityQueue,使用记录的id作为优先级完成有序出队列,但是发现PriorityQueue不是线程安全的,于是找到了PriorityBlockingQueue,说是阻塞的,但是发现提供的几个入队方法都是非阻塞的。那么问题来了,我们需要一个:

  • 阻塞的
  • 线程安全的
  • 顺序出队列的
    于是考虑封装PriorityBlockingQueue

2- LinkedBlockingQueue源码分析

2-1 重要成员变量

用来存储队列中的元素,是个模板类

    /**
     * Linked list node class
     */
    static class Node<E> {
   
        E item;
        Node<E> next;
        Node(E x) { item = x; }
    }

其他成员变量,就不一一解释了,代码中给出了明确的解释,下边分析方法时会进一步解释

    private final int capacity;//总大小,队列元素个数不能超过这个总大小

    /** Current number of elements */
    private final AtomicInteger count = new AtomicInteger();

    /**
     * Head of linked list.
     * Invariant: head.item == null
     */
    transient Node<E> head;

    /**
     * Tail of linked list.
     * Invariant: last.next == null
     */
    private transient Node<E> last;

    /** Lock held by take, poll, etc */
    private final ReentrantLock takeLock = new ReentrantLock();

    /** Wait queue for waiting takes */
    private final Condition notEmpty = takeLock.newCondition();

    /** Lock held by put, offer, etc */
    private final ReentrantLock putLock = new ReentrantLock();

    /** Wait queue for waiting puts */
    private final Condition notFull = putLock.newCondition();

2-2 插入方法

put(E e): 阻塞插入方法
offer(E e, long timeout, TimeUnit unit):非阻塞插入方法,但是会等待一个超时时间,超时才返回false
boolean offer(E e):非阻塞插入方法,不等待超时,如果不能插入就返回false

2-2-1 put方法

原型:public void put(E e) throws InterruptedException
这是一个阻塞方法,如果队列满了,就等待

        if (e == nu
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值