PriorityBlockingQueue 优先级队列
1. PriorityBlockingQueue 简介
PriorityBlockingQueue是一个支持优先级排序的无界阻塞队列,可以通过自定义实现 compareTo()方法来指定元素的排序规则
put(E e)
:将元素插入到队列中。永远不会阻塞take()
: 从队列中取出一个元素。如果队列为空,线程将会被阻塞,直到有生产者插入元素。
package study;
import lombok.Data;
import java.util.Comparator;
import java.util.concurrent.PriorityBlockingQueue;
public class PriorityBlockingQueueDemo {
public static void main(String[] args) throws InterruptedException {
PriorityBlockingQueue<Student> queue = new PriorityBlockingQueue<>(10, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
return o1.getAge() - o2.getAge();
}
});
queue.put(new Student(1, "tom1"));
queue.put(new Student(3, "tom3"));
queue.put(new Student(2, "tom2"));
System.out.println(queue.take());
System.out.println(queue.take());
System.out.println(queue.take());
}
@Data
static
class Student {
private int age;
private String name;
public Student(int age, String name) {
this.age = age;
this.name = name;
}
}
}
put(E e):将元素插入到队列中。如果队列已满,线程将会被阻塞,直到有消费者取走元素。
take():从队列中取出一个元素。如果队列为空,线程将会被阻塞,直到有生产者插入元素。
poll():从队列中取出一个元素,如果队列为空,返回null。
size():返回队列中的元素个数。
isEmpty():判断队列是否为空。
isFull():判断队列是否已满。
不积跬步,无以至千里;不积小流,无以成江海。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具