PriorityQueue是Java内置的优先队列,每次取出来的元素是最小的。PriorityQueue可以做到自动扩容。PriorityQueue中的对象必须是可比较的。
例如,最简单的情况,在PriorityQueue中保存整数:
PriorityQueue<Integer> priInt = new PriorityQueue<>();
然后在其中依次添加五个整数(注意,在PriorityQueue中添加对象,可以调用add,也可以调用offer。)
priInt.add(1);
priInt.add(3);
priInt.add(4);
priInt.add(5);
priInt.add(2);
然后通过poll函数所取出来的值就是从小到大排列好的1,2,3,4,5
int n = priInt.poll(); // n is 1 n = priInt.poll(); // n is 2 n = priInt.poll(); // n is 3 n = priInt.poll(); // n is 4 n = priInt.poll(); // n is 5
PriorityQueue中还可以放置自定义对象。由于PriorityQueue中的对象必须是可比较的,所以必须为自定义对象定义比较规则。
例如,对于自定义类
class MyClass { int n1; int n2; public MyClass(int n1, int n2) { this.n1 = n1; this.n2 = n2; } }
具体做法有3种
1、MyClass实现接口Comparable,在override的函数compareTo中定义比较规则
static class MyClass implements Comparable<MyClass> { int n1; int n2; public MyClass(int n1, int n2) { this.n1 = n1; this.n2 = n2; } @Override public int compareTo(MyClass o) { return this.n2 - o.n2; } }
然后,PriorityQueue上就不用做任何额外的操作了,直接定义即可
PriorityQueue<MyClass> priMyClass = new PriorityQueue<>();
2、在PriorityQueue的参数中,通过Comparator接口定义比较规则
PriorityQueue<MyClass> priMyClass = new PriorityQueue<>( new Comparator<MyClass>() { public int compare(MyClass o1, MyClass o2) { return o1.n2 - o2.n2; } } );
3、在PriorityQueue的参数中,通过lambda表达式定义比较规则。写起来最省事
PriorityQueue<MyClass> priMyClass = new PriorityQueue<>((MyClass o1, MyClass o2) -> o1.n2 - o2.n2);