java.util.concurrent.LinkedBlockingDeque源码学习(二)

LinkedBlockingDeque中的重要方法:

1. boolean linkFirst(E e)
2. boolean linkLast(E e)
插入一个节点到队列头/尾。如果队列已满,则返回false,否则生成一个节点并插入队列,然后唤醒一个等待notEmpty条件的线程,返回true
3. E unlinkFirst()
4. E unlinkLast()
删除处在队列头/尾的节点。如果队列为空,则返回null,否则执行删除,然后唤醒一个等待notFull条件的线程,返回被删除的元素
5. void unlink(Node<E> x)
删除指定节点,唤醒所有等待notFull条件的线程
6. boolean offerFirst(E e)
7. boolean offerLast(E e)== boolean offer(E e)
8. boolean offerFirst(E e, long timeout, TimeUnit unit)
9. boolean offerLast(E e, long timeout, TimeUnit unit)== boolean offer(E e, long timeout, TimeUnit unit)
在锁定状态下插入一个节点到队列头/尾。如果指定的元素为null,则抛出NullPointerException异常。插入过程调用linkFirst/linkLast方法。如果队列已满则直接返回false
10. E pollFirst()==E poll()
11. E pollLast()
12. E pollFirst(long timeout, TimeUnit unit)== E poll(long timeout, TimeUnit unit)
13. E pollLast(long timeout, TimeUnit unit)
在锁定状态下删除处在队列头/尾的节点。调用unlinkFirst/unlinkLast方法。如果队列为空则直接返回null
14. void putFirst(E e)
15. void putLast(E e)== void put(E e)
在锁定状态下插入一个节点到队列头/尾。如果指定的元素为null,则抛出NullPointerException异常。插入过程调用linkFirst/linkLast方法。如果队列已满则当前线程进入等待区
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值