阻塞队列-BlockingQueue

本文详细介绍了Java中的阻塞队列BlockingQueue,包括其6种主要实现,如ArrayBlockingQueue、LinkedBlockingQueue等。讨论了阻塞队列的关键方法如take、put等,以及其并发安全的实现机制,如ReentrantLock和Condition。同时,对比了阻塞队列与非阻塞队列如ConcurrentLinkedQueue的区别,并提到了线程池对阻塞队列的选择。
摘要由CSDN通过智能技术生成

阻塞队列

public interface BlockingQueue extends Queue{…}
在这里插入图片描述
在这里插入图片描述

BlockingQueue 下面有 6 种最主要的实现,分别是 ArrayBlockingQueue、LinkedBlockingQueue、SynchronousQueue、DelayQueue、PriorityBlockingQueue 和 LinkedTransferQueue

take方法

获取并移除队列的头结点

一旦执行 take 方法的时候,队列里无数据,则阻塞,直到队列里有数据。一旦队列里有数据了,就会立刻解除阻塞状态,并且取到数据

pull方法

插入元素

如果队列已满,那么就无法继续插入,则阻塞,直到队列里有了空闲空间


无界队列 LinkedBlockingQueue

有界队列 ArrayBlockingQueue


BlockingQueue 中最常用的和添加、删除相关的 8 个方法

1、抛出异常:add、remove、element
2、返回结果但不抛出异常:offer、poll、peek
3、阻塞:put、take

add<

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值