今天小编给大家分享的是JavaSE中compare、compareTo有什么区别,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。
在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),那么,返回值有三种结果情况,分别如下:
若返回值为负数,则说明a
若返回值为0,则说明a=b;
若返回值为正数,则说明a>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()方法一致,具体如下:
若返回值为负数,则说明a
若返回值为0,则说明a=b;
若返回值为正数,则说明a>b;
方法的比较
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; } }
写个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; }
再来看下价格。
我们来实现一个比较器,实现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有什么区别就分享到这里了,希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。