Python 官方文档:入门教程 => 点击学习
目录 1.前言2.环境说明3.概述3.1Comparable 简介3.2Comparable 定义3.3Comparator 简介3.4Comparator 定义3.5区别
在java当中,若是进行比较,大家可能第一时间想到,==或是!=,这种数学上的比较符>、
接下来,我就分别介绍并演示这两种实现方法。
环境说明:windows10 + idea2021.3.2 + jdk1.8 + SpringBoot 2.3.1.RELEASE
首先Comparable是一个排序接口,这也就表示若一个类实现了Comparable接口,则意味着该类支持排序。
public interface Comparable<T> {
public int compareTo(T o);
}
Comparable 接口仅提供了一个函数方法compareTo(),它的定义如下:
那具体该方法有何作用呢?请接着往下看。
compareTo()方法返回的是一个int类型值, 这里我着重给大家介绍一下。
若你使用compareTo()进行a与b的比较,eg:a.compareTo(b),那么,返回值有三种结果情况,分别如下:
其中,String类就是一个典例,它就是实现了Comparable接口。
其中就重写了Comparable接口中的compareTo()方法,具体实现逻辑大家可以借鉴。
接下来,我再给大家讲解一下Comparator接口。
首先Comparator是一个比较器接口,用于类设计已经完成,还想排序(Arrays)的情况下使用。
目前它只提供了两个函数供使用。
public interface Comparator<T> {
int compare(T o1, T o2);
boolean equals(Object obj);
}
针对Comparator接口,若一个类实现了它,只需要实现compare()方法即可,可以不用实现equals方法,因为任何类的超类都是Object,查看Object类也可得知equals()就被实现了。
该方法 int compare(T a, T b) 是“比较a和b的大小”。返回值结果情况与compareTo()方法一致,具体如下:
方法的比较
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 是比较器接口。
接下来我先给大家演示下如何实现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;
}
}
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;
}
再来看下价格。
我们来实现一个比较器,实现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函数输出结果如下截图:
到此这篇关于JavaSE中compare、compareTo的区别的文章就介绍到这了,更多相关Java compare、compareTo内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: JavaSE中compare、compareTo的区别
本文链接: https://lsjlt.com/news/214101.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0