并发容器:阻塞队列之PriorityBlockingQueue

1 介绍

PriorityBlockingQueue优先级阻塞队列是一个“无边界”阻塞队列,该队列会根据某种规则(Comparator)对插入队列尾部的元素进行排序,因此该队列将不会遵循FIFO(first-in-first-out)的约束

2 使用

2.1 构造

只要应用程序的内存足够使用,理论上,PriorityBlockingQueue存放数据的数量是“无边界”的,**在PriorityBlockingQueue内部维护了一个Object的数组,随着数据量的不断增多,该数组也会进行动态地扩容。**在构造PriorityBlockingQueue时虽然提供了一个整数类型的参数,但是该参数所代表的含义与ArrayBlockingQueue完全不同,前者是构造PriorityBlockingQueue的初始容量,后者指定的整数类型参数则是ArrayBlockingQueue的最大容量。

public PriorityBlockingQueue(int initialCapacity);
// comparator指定排序规则
public PriorityBlockingQueue(int initialCapacity, Comparator<? super E> comparator) 
 public static void main(String[] args) {
     // 定义队列的初始容量是3
     PriorityBlockingQueue<Integer> queue = new PriorityBlockingQueue<>(3);
     queue.put(1);
     queue.put(2);
     queue.put(3);
     queue.put(4);
     queue.forEach(System.out::print);
 }

如果没有显示地指定Comparator,那么它将只支持实现了Comparable接口的数据类型。在上例中,Integer类型是Comparable的子类,因此我们并不需要指定Comparator,默认情况下,优先级最小的数据元素将被放在队列头部,优先级最大的数据元素将被放在队列尾部。

2.2 不存在阻塞写方法

由于PriorityBlockingQueue是“无边界”的队列,因此将不存在对队列上限临界值的控制,在PriorityBlockingQueue中,添加数据元素的所有方法都等价于offer方法,从队列的尾部添加数据,但是该数据会根据排序规则对数据进行排序。

// put 方法底层调用的就是offer
public void put(E e) {
    offer(e); // never need to block
}

2.3 优先级队列读方法

优先级队列添加元素的方法不存在阻塞(由于是“无边界”的),但是针对优先级队列元素的读方法则与ArrayBlockingQueue类似,可参考ArrayBlockingQueue

并发容器:阻塞队列之ArrayBlockingQueue

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值