-
- equals 方法
-
总结
-
三种比较方式对比
-
集合框架中PriorityQueue的比较方式
-
本文结束
=================================================================
在上篇文章Heap —— Priority Queue - 堆/优先级队列中,优先级队列在插入元素不能是null 或者 元素之间必须要能狗进行比较。
为了简单起见,我们只是插入了 Integer 类型,那优先级队列中能否插入自定义的数据类型对象?
=================================================================
通过实践,我们发现在没有指定 某种排序规则时,是无法将自定义类型入队的。
至于 Comparable,可以参考这篇文章面向对象的编程(三个常用接口)
关于 对象的比较来说:
1、equals 方法,比较的是对象,如果比较的两个对象不相同:返回 false,反之,返回true
2、比较大小
我们的 Comparable 和 compareTo 使用比较大小的。
总结
因为我们Card类,指定的类型 没有具有指定的比较能力。
所以,我们需要去指定 某种排序的规则。
方法一: 实现Comparable 接口 【注意!实现结结构,是要重写接口内部的抽象方法的】
import java.util.PriorityQueue;
// 扑克牌
class Card implements Comparable{
public int point;// 点数
public String suit;// 花色
public Card(int point,String suit){
this.point = point;
this.suit = suit;
}
// 重写