阻塞队列,就是相当于给你预估值,这些值,阻塞队列给你处理
一、阻塞队列

当队列是空的,从队列中 获取 元素的操作将会被阻塞
当队列是满的,从队列中 添加 元素的操作将会被阻塞
试图从空的队列中获取元素的线程将会被阻塞,直到其他线程往空的队列插入新的元素
试图向已满的队列中添加新元素的线程将会被阻塞,直到其他线程从队列中移除一个或多个元素或者完全清空,使队列变得空闲起来并后续新增
二、用处
在多线程领域:所谓阻塞,在某些情况下会 挂起 线程(即阻塞),一旦条件满足,被挂起的线程又会自动 被唤起
为什么需要BlockingQueue
好处是我们不需要关心什么时候需要阻塞线程,什么时候需要唤醒线程,因为这一切BlockingQueue都给你一手包办了
在concurrent包发布以前,在多线程环境下, 我们每个程序员都必须去自己控制这些细节,尤其还要兼顾效率和线程安全 ,而这会给我们的程序带来不小的复杂度。
三、种类
ArrayBlockingQueue:由数组结构组成的有界阻塞队列。
LinkedBlockingQueue:由链表结构组成的有界(但大小默认值为integer.MAX_VALUE)阻塞队列。
PriorityBlockingQueue:支持优先级排序的无界阻塞队列。
DelayQueue:使用优先级队列实现的延迟无界阻塞队列。
SynchronousQueue:不存储元素的阻塞队列,也即单个元素的队列。
LinkedTransferQueue:由链表组成的无界阻塞队列。
LinkedBlockingDeque:由链表组成的双向阻塞队列。
四、核心方法


五、代码
package com.cb.demo.example;
import java.util.Collection;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.TimeUnit;
/**
* 阻塞队列,就是相当于给你预估值,这些值,阻塞队列给你处理
*/
public class BlockingQueueDemo {
public static void main(String[] args) throws InterruptedException {
BlockingQueue<String> blockingQueue=new ArrayBlockingQueue<>(3);
/*System.out.println(blockingQueue.add("a"));
System.out.println(blockingQueue.add("b"));
System.out.println(blockingQueue.add("c"));
//Exception in thread "main" java.lang.IllegalStateException: Queue full
//System.out.println(blockingQueue.add("X"));
System.out.println(blockingQueue.remove());
System.out.println(blockingQueue.remove());
System.out.println(blockingQueue.remove());
//Exception in thread "main" java.util.NoSuchElementException
//System.out.println(blockingQueue.remove());
System.out.println(blockingQueue.add("b"));
System.out.println(blockingQueue.add("c"));
System.out.println(blockingQueue.element()); //检查队列首位元素*/
//offer 判断添加是否成功
/* System.out.println(blockingQueue.offer("A"));
System.out.println(blockingQueue.offer("B"));
System.out.println(blockingQueue.offer("C"));
System.out.println(blockingQueue.offer("X"));
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());*/
/* blockingQueue.put("A");
blockingQueue.put("B");
blockingQueue.put("C");
//blockingQueue.put("A");
System.out.println(blockingQueue.take());
System.out.println(blockingQueue.take());
System.out.println(blockingQueue.take());
System.out.println(blockingQueue.take());
*/
System.out.println(blockingQueue.offer("B"));
System.out.println(blockingQueue.offer("C"));
System.out.println(blockingQueue.offer("X"));
System.out.println(blockingQueue.offer("E",3L, TimeUnit.SECONDS));
}
}
本文介绍了Java中的阻塞队列BlockingQueue,它在多线程环境中起到关键作用,自动处理线程的阻塞和唤醒。 BlockingQueue包含多种实现,如ArrayBlockingQueue、LinkedBlockingQueue等,提供了add、remove、offer和put等核心方法。通过实例代码展示了其用法,帮助理解阻塞队列的工作原理和应用场景。
564

被折叠的 条评论
为什么被折叠?



