Java多线程—BlockingQueue

本文深入探讨了Java中的阻塞队列BlockingQueue,包括其核心方法如压入和弹出元素,以及如何在队列满或空时进行阻塞处理。此外,还介绍了其实现类和在生产者消费者模式中的应用示例。
摘要由CSDN通过智能技术生成

BlockingQueue

阻塞队列,所谓的阻塞是指,当队列已满时,会阻塞当前添加元素的线程,直到队列不满或者等到超时;当队列为空时,会阻塞当前获取元素的线程,直到队列不空或者等待超时。

核心方法

压入元素

  • add(E e):向队尾增加元素,设置成功返回true。如果使用了capacity-restricted队列,即限定了容量的队列,推荐使用offer()方法。
  • offer(E e):向队尾增加元素,设置成功返回true,如果队列中没有多余的空间返回false。
  • put(E e):向队尾增加元素,如果队列中没有多余的空间,该方法会一直阻塞。

弹出元素

  • poll():获取并移除队首元素,如果队列为空,返回null。

  • take():获取并移除队首元素,如果队列为空,该方法会一直阻塞。

  • peek():获取但是并不移除队首元素,如果队列为空,返回null。

其他操作

  • contains(Obeject o):判断队列中是否包含该元素。
  • int drainTo(Collection<? super E> c):将队列转化为集合。

实现类

实现类 底层数据结构 是否有界 其他
ArrayBlockingQueue arrayList 有界 只有一把锁,入队高并发或出队高并发的情况下推荐使用
LinkedBlockingQueue linkedList 默认无界,可指定上限 两把锁,在入队与出队都高并发的情况下推荐使用
DelayQueue heap 无界 延迟期满时才能从中提取元素
PriorityBlockingQueue heap 无界 基于优先级的阻塞队列
SynchronousQueue 有界 无缓冲的阻塞队列,只能容纳一个元素,向队列中插入一个新元素的线程将会阻塞,直到另一个线程将该元素从队列中抽走。

生产者消费者例子

Producer.java

import java.util.concurrent.BlockingQueue;
import java.util.concurrent.TimeUnit;

/**
 * @author liuergo
 * @description 生产者
 * @date 2019-11-10 00:23
 */

public class Producer implements Runnable {
   
    private final BlockingQueue
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值