jdk10 LinkedBlockingQueue阅读笔记

本文详细探讨了LinkedBlockingQueue的构造函数、入队(offer/put)、出队(poll/take)以及其他相关操作。通过分析其内部结构和并发机制,展示了该队列在并发场景下的高效使用。
摘要由CSDN通过智能技术生成
  • 一个常用的并发队列,链表实现

有效构造函数

  • 构造函数1
public LinkedBlockingQueue(int capacity) {
        if (capacity <= 0) throw new IllegalArgumentException();
        this.capacity = capacity;
        last = head = new Node<E>(null);
    }

    设置了queue的容量,队首=队尾=首节点( new Node<E>(null) )

    看一下这个node的结构,一个很简单的链表节点:

static class Node<E> {
        E item;
        Node<E> next;

        Node(E x) { item = x; }
    }
  • 构造函数2
public LinkedBlockingQueue(Collection<? extends E> c) {
        this(Integer.MAX_VALUE);
        final ReentrantLock putLock = this.putLock;
        putLock.lock(); // Never contended, but necessary for visibility
        try {
            int n = 0;
            for (E e : c) {
                if (e == null)
                    throw new NullPointerException();
                if (n == capacity)
                    throw new IllegalStateException("Queue full");
                enqueue(new Node<E>(e));
                ++n;
            }
            count.set(n);
        } finally {
            putLock.unlock();
        }
    }

    队列容量是Integer.MAX_VALUE,将入参collection中的元素都添加到队列中

入队操作

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值