JavaSE中compare、compareTo的区别
作者:bug菌 时间:2021-12-28 09:37:47
1.前言
在java当中,若是进行比较,大家可能第一时间想到,==或是!=,这种数学上的比较符>、
接下来,我就分别介绍并演示这两种实现方法。
2.环境说明
环境说明:Windows10 + Idea2021.3.2 + Jdk1.8 + SpringBoot 2.3.1.RELEASE
3.概述
3.1Comparable 简介
首先Comparable是一个排序接口,这也就表示若一个类实现了Comparable接口,则意味着该类支持排序。
public interface Comparable<T> {
public int compareTo(T o);
}
3.2Comparable 定义
Comparable 接口仅提供了一个函数方法compareTo(),它的定义如下:
那具体该方法有何作用呢?请接着往下看。
compareTo()方法返回的是一个int类型值, 这里我着重给大家介绍一下。
若你使用compareTo()进行a与b的比较,eg:a.compareTo(b),那么,返回值有三种结果情况,分别如下:
若返回值为负数,则说明a
若返回值为0,则说明a=b;
若返回值为正数,则说明a>b;
其中,String类就是一个典例,它就是实现了Comparable接口。
其中就重写了Comparable接口中的compareTo()方法,具体实现逻辑大家可以借鉴。
3.3Comparator 简介
接下来,我再给大家讲解一下Comparator接口。
首先Comparator是一个比较器接口,用于类设计已经完成,还想排序(Arrays)的情况下使用。
目前它只提供了两个函数供使用。
public interface Comparator<T> {
int compare(T o1, T o2);
boolean equals(Object obj);
}
3.4Comparator 定义
针对Comparator接口,若一个类实现了它,只需要实现compare()方法即可,可以不用实现equals方法,因为任何类的超类都是Object,查看Object类也可得知equals()就被实现了。
该方法 int compare(T a, T b) 是“比较a和b的大小”。返回值结果情况与compareTo()方法一致,具体如下:
若返回值为负数,则说明a
若返回值为0,则说明a=b;
若返回值为正数,则说明a>b;
3.5区别
方法的比较
1.compareTo(Object obj)方法是java.lang.Comparable接口中的方法, 当需要对类的对象进行排序时,该类需要实现Comparable接口,必须重写compareTo(T o)方法。
比如String类等一些类默认实现了该接口,重写了 compareTo()方法,例如s1.compareTo(s2),自然返回值就是s1 与 s2 的ASC码差值,其实就是字典排序;
2.compare(Object o1, Object o2)方法是java.util.Comparator接口的方法, 它实际上用的是待比较对象的compare(T o1, T o2)方法;
3、Comparable 是排序接口,而Comparator 是比较器接口。
4. 实例演示
4.1.Comparable使用演示
接下来我先给大家演示下如何实现Comparable接口的compareTo()方法进行排序。
@Data
public class Dog implements Comparable<Dog> {
private String type;
private double price;
public Dog() {
}
public Dog(String name, int price) {
this.type = name;
this.price = price;
}
public String toString() {
return "狗品种为:" + type + ",价格为:" + price;
}
@Override
public int compareTo(Dog o) {//升序
if (this.price > o.price) {
return 1;
} else if (this.price < o.price) {
return -1;
}
return 0;
}
}
写个main函数进行测试验证。演示代码如下:
public class ComparableTest {
public static void main(String[] args) {
Dog[] dogs = {
new Dog("泰迪", 10),
new Dog("柯基", 78),
new Dog("柴犬", 55),
new Dog("藏獒", 42),
new Dog("斗牛犬", 15)
};
//升序
Arrays.sort(dogs);
for (Dog dog : dogs) {
System.out.println(dog);
}
}
}
执行main函数,控制台打印如下:
我们再调整一下排序规则,改为按对象中price价格进行降序。
@Override
public int compareTo(Dog o) {//降序
if (this.price < o.price) {
return 1;
} else if (this.price > o.price) {
return -1;
}
return 0;
}
再来看下价格。
4.2 Comparable使用演示
我们来实现一个比较器,实现Comparator接口的compare()方法,其中泛型我直接指定Dog对象。演示代码具体如下:
public class ComparatorDog implements Comparator<Dog> {
@Override
public int compare(Dog o1, Dog o2) {
//升序
if (o1.getPrice() > o2.getPrice()) {
return 1;
} else if (o1.getPrice() < o2.getPrice()) {
return -1;
}
return 0;
}
}
写个测试类进行测试用例打印:
public static void main(String[] args) {
Dog[] dogs = {
new Dog("泰迪", 10),
new Dog("柯基", 78),
new Dog("柴犬", 55),
new Dog("藏獒", 42),
new Dog("斗牛犬", 15)
};
//升序
Arrays.sort(dogs,new ComparatorDog());
for (Dog dog : dogs) {
System.out.println(dog);
}
}
接下来运行main函数,大家请看控制台输出截图:
我们稍微调整下排序规则,将升序改为降序。具体修改如下:
@Override
public int compare(Dog o1, Dog o2) {
//降序
if (o1.getPrice() < o2.getPrice()) {
return 1;
} else if (o1.getPrice() > o2.getPrice()) {
return -1;
}
return 0;
}
我们运行main函数输出结果如下截图:
来源:https://juejin.cn/post/7232577434473922618