Comparable中的compareTo方法和Comparator中的compare方法的比较
使用场景
Comparable接口是在java的lang包下
Comparable接口的compareTo方法用在实体类上,实现对象按某种方式排序
如下:实现对Person对象以年龄作为排序的规则的写法
排序规则
升序排列:用当前对象的值-目标对象的值
降序排列:用目标对象的值-当前对象的值,或者是在升序的情况下加个负号 -(this.age - o.age)
public class Person implements Comparable<Person> {
public String name;
public int age;
@Override
public int compareTo(Person o) {
return this.age-o.age;
}
}
Comparator接口是在java的util包下
Comparator接口的compare方法主要用于实现业务的排序,可以实现两个入参的。
同样的也要在实现接口的时候指定排序的对象的类型
class A implements Comparator<Person> {
@Override
public int compare(Person o1, Person o2) {
return o1.age -o2.age;
}
}
多条件排序时可以使用下面的方式进行,按字段的优先级来设计排序的规则
参考如下方式:
//时间降序 点击量升序 标题降序
@Override
public int compareTo(Items o) {
int result = 0;
//按照生产时间降序
result = - this.pubTime.compareTo(o.pubTime);
if(0==result){//如果生产时间相同 就按照销售量升序排列
result = this.hits-o.hits;
if(0==result){//如果销售量相同 按照名字降序排列
result = - this.title.compareTo(o.title);
}
}
return result;
排序规则实际上是按下面的原则进行比较的:
返回值为-1, 表示左边的数比右边的数小,左右的数不进行交换。
返回值为0, 表示左边的数等于右边的数,左右的数不进行交换。
返回值为1, 表示左边的数比右边的数大,左右的数进行交换。(不进行交换的话,就没办法维持升序)