javase中compare、compareto有什么区别
本文讲解"javase中compare、compareto有什么区别",希望能够解决相关问题。
目录1.前言
在java当中,若是进行比较,大家可能第一时间想到,==或是!=,这种数学上的比较符>、
接下来,我就分别介绍并演示这两种实现方法。
2.环境说明
环境说明:windows10 + idea2021.3.2 + jdk1.8 + springboot 2.3.1.release
3.概述
3.1comparable 简介
首先comparable是一个排序接口,这也就表示若一个类实现了comparable接口,则意味着该类支持排序。
public interface comparable {
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 {
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 {
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 {
@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函数输出结果如下截图:



