阻塞队列BlockingQueue

这篇具有很好参考价值的文章主要介绍了阻塞队列BlockingQueue。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

阻塞队列BlockingQueue

队列

先进先出的数据结构,允许出队的一端称为队头,允许入队的一端称为队尾。

阻塞队列BlockingQueue

在java中为队列定义了一个接口规范Queue接口

public interface Queue<E> extends Collection<E> {
   
    //添加一个元素,添加成功返回true, 如果队列满了,就会抛出异常
    boolean add(E e);
    
    //添加一个元素,添加成功返回true, 如果队列满了,返回false
    boolean offer(E e);
    
    //返回并删除队首元素,队列为空则抛出异常
    E remove();
    
    //返回并删除队首元素,队列为空则返回null
    E poll();
    
    //返回队首元素,但不移除,队列为空则抛出异常
    E element();
    
    //获取队首元素,但不移除,队列为空则返回null
    E peek();
}



阻塞队列

阻塞队列提供了线程安全的队列访问方式。多线程入队互斥,多线程出队互斥,队列满了阻塞生产者线程,队列空了阻塞消费者线程

阻塞队列的接口BlockingQueue 它继承了 Queue接口。并在原有Queue接口定义的方法规范下,再新增了两个关于阻塞的方法规范。

public interface BlockingQueue<E> extends Queue<E> {
   

    // 阻塞方式 入队
    void put(E e) throws InterruptedException;

    // 阻塞方式 出队
    E take() throws InterruptedException;

   ......

}



方法 抛出异常 返回特定值 阻塞 阻塞特定时间
入队 add(e) offer(e) put(e) offer(e, time, unit)
出队 remove() poll() take() poll(time, unit)
获取队首元素 element() peek() 不支持 不支持

阻塞队列的应用场景

  • 线程池
  • 生产者-消费者模型
  • 消息队列
  • 缓存系统
  • 并发任务处理

BlockingQueue 接口的实现类都被放在了 juc 包中,它们的区别主要体现在存储结构上或对元素操作上的不同,但是对于take与put操作的原理却是类似的。

队列 描述
ArrayBlockingQueue 基于数组结构实现的一个有界阻塞队列
LinkedBlockingQueue 基于链表结构实现的一个无界阻塞队列,指定容量为有界阻塞队列
PriorityBlockingQueue 支持按优先级排序的无界阻塞队列
DelayQueue 基于优先级队列(PriorityBlockingQueue)实现的无界阻塞队列
SynchronousQueue 不存储元素的阻塞队列
LinkedTransferQueue 基于链表结构实现的一个无界阻塞队列
LinkedBlockingDeque 基于链表结构实现的一个双端阻塞队列

详情



ArrayBlockingQueue

简介

ArrayBlockingQueue它队列使用的数据结构是双指针的环形数组,入队出队是基于生产者消费者模型实现的,它入队和出队使用的是同一把锁。


基本使用

BlockingQueue queue = new ArrayBlockingQueue(1024);
queue.put("1");   //向队列中添加元素
Object object = queue.take();   //从队列中取出元素

其实ava.util.concurrent.locks.Condition接口的注释中 给出的案例就和ArrayBlockingQueue的实现很相似,如下所示使用一个环形数组实现生产者消费者模式:文章来源地址https://www.toymoban.com/news/detail-406720.html

class BoundedBuffer {
   
    final Lock lock = new ReentrantLock();
    final Condition notFull  = lock.newCondition(); 
    final Condition notEmpty = lock.newCondition(); 

    final Object[] items = new Object[100];
    int putptr, takeptr, count;

    // 生产者,把方法的入参往队列中存,队列是一个环形数组
    public void put(Object x) throws InterruptedException {
   
        lock.lock();
        try {
   
            
            // 队列放满了生产者就阻塞
            while (count == items.length)
                notFull.await();
            
            // 往队列存数据
            items[putptr] = x;
            if (++putptr == items.length) putptr = 0;
            
            // 队列中新存值了,要通知消费者开始消费了
            ++count;
            notEmpty.signal();
        } finally {
   
            lock.unlock();
        }
    }

    // 消费者,从队列中取
    public Object take() throws InterruptedException {
   
        lock.lock();
        try {
   
            
            // 队列空了,消费者就阻塞
            while (count == 0)
                notEmpty.await();
            
            // 从队列中取值
            Object x = items[takeptr];
            if (++takeptr == items.length) takeptr = 0;
            
            // 已经消费了,队列现在不是满的了,唤醒生产者进行生产
            --count;
            notFull.signal();
            return x;
        } finally {
   
            lock.unlock();
        }
    }

到了这里,关于阻塞队列BlockingQueue的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 什么是Java中的阻塞队列和非阻塞队列?

    首先,让我们从基础概念开始。在计算机科学中,数据结构可以分为两种:队列和管道。队列是一种先进先出(FIFO)的数据结构,你可以想象成排队买电影票的情况。你加入队伍的时候,你可以决定站在哪里,但是一旦决定站在哪里,你就不能改变位置。而一旦你到达队尾,

    2024年02月14日
    浏览(33)
  • 阻塞队列(消息队列)

    队列是一种先进先出的数据结构。而阻塞队列也是一种特殊的队列,也遵守”先进先出“的原则。 阻塞队列是一种线程安全的的数据结构,并且具有以下 特性 : 1、队列往进写元素是从队尾插入,队首取出 2、当插入元素的时候,先判断一下,队列是否已经满了,如果满了就

    2024年02月11日
    浏览(30)
  • 【数据结构-队列】阻塞队列

    💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学习,不断总结,共同进步,活到老学到老 导航 檀越剑指大厂系列:全面总

    2024年02月09日
    浏览(28)
  • 10.阻塞队列和线程池

    阻塞队列(BlockQueue) 非阻塞方法 add 往满的队列中添加元素会报错 remove 从空的队列中移除元素会报错 offer 往满的队列中添加元素会返回false poll 从空的队列中移除元素会返回null 阻塞方法 put take 使用场景: 阻塞队列通常使用在生产者消费者设计模式当中,生产者不用关心生成的

    2024年02月04日
    浏览(26)
  • 阻塞队列.

    目录 ♫什么是阻塞队列 ♫什么是生产-消费者模式 ♫实现一个阻塞队列 ♫BlockingQueue 阻塞队列是一种特殊的队列,它除了具备队列的先进先出的特点外,还具有以下特点: ♩. 如果队列为空时,执行出队列操作,会阻塞等待,直到另一个线程往队列里添加元素(队列不为空)

    2024年02月08日
    浏览(51)
  • 阻塞队列(JAVA)

    阻塞队列是一种特殊的队列,也遵守 \\\"先进先出\\\" 的原则。 阻塞队列能是一种 线程安全的数据结构 , 并且具有以下特性: 当队列满的时候, 继续入队列就会阻塞, 直到有其他线程从队列中取走元素; 当队列空的时候, 继续出队列也会阻塞, 直到有其他线程往队列中插入元素。  

    2024年02月02日
    浏览(27)
  • 阻塞队列的原理及应用

    阻塞队列是一种常用的并发编程工具,它能够在多线程环境下提供一种安全而高效的数据传输机制。本文将介绍阻塞队列的原理和使用场景,并通过实例演示其在多线程编程中的应用。 阻塞队列是一种特殊的队列,它具有以下几个特点: 阻塞特性:当队列为空时,从队列中

    2024年02月10日
    浏览(26)
  • 阻塞队列是什么

    (1) 栈与队列 1)栈:先进后出,后进先出 2)队列:先进先出 (2) 阻塞队列 阻塞:必须要阻塞/不得不阻塞 阻塞队列是一个队列,在数据结构中起的作用如下图: 1)当队列是空的,从队列中获取元素的操作将会被阻塞。 2)当队列是满的,从队列中添加元素的操作将会被阻塞

    2024年02月13日
    浏览(29)
  • Qt QQueue 安全的多线程队列、阻塞队列

    在C++中,queue是一个模板类,用于实现队列数据结构,遵循先进先出的原则。 ♦ 常用方法: · ♦ 简单使用: · ♦ 打印: · QQueue 继承与 QList ♦ 常用方法: · ♦ 实例: · ♦ 打印: · 在多线程编程中,由于QQueue并不是线程安全的,因此我们需要先使用互斥锁(QMutex)来保

    2024年02月16日
    浏览(25)
  • 【Linux驱动】Linux阻塞IO —— 阻塞读取按键状态(等待队列实现)

    上一节获取按键状态时,是在应用层以循环的方式不断读取按键状态,但是我们实际关注的只是当按键被按下时发生的情况,所以大多数时间拿到的状态都是我们不需要的结果。 对此,当按键被释放时,让 read 接口处于阻塞状态,等按键被按下再解除阻塞。 要使用等待队列

    2024年02月02日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包