本文已参与「掘力星计划」,赢取创作大礼包,挑战创作激励金。 @[TOC]
一:问题引出
在使用优先级队列(堆)的时候,优先级队列对插入的元素要求必须是可以互相进行比较的元素,并且不能是null。
那么怎么比较自定义类的对象呢?
@TOC
二:Java中比较的几种方式
2.1 在Java中基本类型可以直接进行比较
1 | java复制代码public class TestCompare { |
输出结果:
对于基本类型,可以直接用’=’,’>’,‘<’等其他符号比较,返回true,或者是false。
2.2 对象的比较
1.引入
1 | java复制代码class Card { |
从结果中可以看出Java中引用类型的比较不能直接按照‘<’,’>’比较。编译器会报错,那为什么‘==’可以呢?因为对于自定义的类型,都默认的继承了Object类,而Object类中提供了equal方法,而‘==’默认情况下调用的就是equal方法,equal方法比较的并不是两个变量的值的大小,而是直接比较两个引用变量的地址。
三:对象的比较
3.1 覆写基类的equal方法
在2.2中自定义类型equal方法比较的是两个变量的地址而不是大小,那要是硬要比较大小应该怎么做呢?我们可以覆写基类的equal方法
1 | java复制代码@Override |
覆写的格式大同小异
1. 如果两个变量都指向同一个变量那么返回true;
2. 如果有传入的变量为null,那么返回false;
3. 如果传入的类型不同,(如上面的例子不是“card“),也返回false;
4. 按照类的实现目标完成比较,例如这里只要花色和数值一样,就认为是相同的牌
总结:覆写基类equal的方式虽然可以比较,但缺陷是:equal只能按照相等进行比较,不能按照大于、小于的方式进行
比较。
3.2 基于Comparble接口类的比较
对于自定义类型比较大小的话,在定义类的时候实现它的Comparble接口,然后在类中重写CompareTo方法
Comparble是JDK提供的泛型的比较接口类,源码实现具体如下:
1 | java复制代码public interface Comparable<E> { |
3.3基于比较器的比较
具体步骤如下:
1:自定义比较器类,实现Comparator接口
1 | java复制代码public interface Comparator<T> { |
2:覆写Comparator中的compare方法`
1 | java复制代码import java.util.Comparator; |
3.4 三种比较方式的对比
四:结尾
上面的就是java中常用的比较变量的方法,由于侵入性不同,需要跟需求选择。
本文转载自: 掘金