一文真正搞懂Java中的自然排序和定制排序,到底升序还是降序
Posted 尚墨1111
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一文真正搞懂Java中的自然排序和定制排序,到底升序还是降序相关的知识,希望对你有一定的参考价值。
1. 自然排序
自然排序:类实现了java.lang.Comparable接口,重写compareTo()的规则
//这里固定指:o1表示位于前面的对象,o2表示后面的对象,并且表示o1比o2小
o1.compareTo(o2)
//升序
Collections.sort(persons, new Comparator<Person>() {
@Override
public int compare(Person o1, Person o2) {
//o1比o2小,直接返回,就是不调整位置,所以是升序
return o1.getAge().compareTo(o2.getAge());
}
});
2.定制排序
定制排序:java.util.Comparator,重写compare方法
//这里o1表示位于前面的对象,o2表示后面的对象
compare(o1,o2)==o1.compareTo(o2)
返回-1(或负数),表示不需要交换01和02的位置,o1依旧排在o2前面,asc,升序
返回1(或正数),表示需要交换01和02的位置,o1排在o2后面,desc,降序
//Collections排序降序
Collections.sort(persons, new Comparator<Person>() {
@Override
public int compare(Person o1, Person o2) {
return o2.getAge().compareTo(o1.getAge());//o2比o1小,所以是降序
}
});
总览
Collections.sort(companyList, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
if(o1.compareTo(o2) < 0 ){//o1比o2小,不调整位置,升序—-->升序
return -1;
}else if(o1.compareTo(o2) == 0){
return 0;
}else{//o2比o1小,调整整位置,降序——>升序
return 1;
}
}
});
以上是关于一文真正搞懂Java中的自然排序和定制排序,到底升序还是降序的主要内容,如果未能解决你的问题,请参考以下文章