java自定义排序规则

文章介绍了如何在Java开发中,根据业务提供的无规则顺序对账单进行排序,通过自定义Comparator类实现排序逻辑,特别提到对于分页查询的处理方式。
摘要由CSDN通过智能技术生成

java自定义排序规则

背景:开发的一个查询功能,主要字段:账号、币种等,业务提供了一个显示顺序,没有什么规则的排序,例如 3,1,6,2 无规则的顺序
思路:通过提供的顺序来指定排序规则

代码:

/**通过提供的顺序,把他们放在list中,表中主键是账号和币种,我就把他们联合起来,这样list中就不会有重复的,就能保证他们的顺序是唯一的*/
List<String> acctOrder = Arrays.asList("1235564-USD", "8524526-JPY", "9652485-CAD");

/**排序方法的入口*/
private void sortResult(List<T> resultlist) {
Collections.sort(resultlist, new AcctComparator());
}


/**自定义一个比较器,T 为比较的类型,可以是String,Integer,也可以是自己定义的对象类型*/
private class AcctComparator implements Comparator<T> {
@Override
public int compare(T o1, T o2) {
int index1 = acctOrder.indexOf(o1.getActAcct() + "-" + o1.getCcy());
int index2 = acctOrder.indexOf(o2.getActAcct() + "-" + o2.getCcy());
/* 如果都不在排序的list中,按照 账号-币种 排序 ,如果不做此判断,当他们都是-1时,可能会报:comparison method violates its general contract(违反了比较方法的一般约定)*/
if (index1 == -1 && index2 == -1) {
return (o1.getActAcct() + "-" + o1.getCcy()).compareTo(o2.getActAcct() + "-" + o2.getCcy());
/* 如果o1不在,放后面 */
} else if (index1 == -1) {
return 1;
/* 如果o2不在,放前面 */
} else if (index2 == -1) {
return -1;
/* 如果都存在,按照所在的顺序排序 */
} else {
return Integer.compare(index1, index2);
}
}
}

总结:通过自定义的排序规则,这样就可以给查到的数据排序了。不过如果是分页查的数据,一定要先查出所有的数据,通过此方法排序后自己去截取数组返回,不然查的数据已经分页过,再排序是没有意义的。

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 中,可以通过实现 `Comparator` 接口来自定义排序规则。 `Comparator` 接口有一个 `compare()` 方法,可以在其中编写自定义的比较逻辑。 假设有一个 `Person` 类,其中包含 `name` 和 `age` 两个字段,现在要按照年龄从小到大排序,如果年龄相同,则按照姓名字典序排序。代码如下: ```java import java.util.Comparator; public class Person { private String name; private int age; // 构造方法和 getter/setter 略 // 自定义比较器 public static Comparator<Person> ageNameComparator = new Comparator<Person>() { @Override public int compare(Person p1, Person p2) { if (p1.getAge() < p2.getAge()) { return -1; } else if (p1.getAge() > p2.getAge()) { return 1; } else { return p1.getName().compareTo(p2.getName()); } } }; } ``` 在上面的代码中,我们定义了一个 `ageNameComparator` 比较器,它可以按照年龄从小到大排序,如果年龄相同,则按照姓名字典序排序。在 `compare()` 方法中,我们首先比较两个 `Person` 对象的年龄,如果年龄不同,就直接返回比较结果;如果年龄相同,就比较两个 `Person` 对象的姓名。 使用自定义的比较器进行排序,可以通过调用 `Collections.sort()` 方法,并传入自定义比较器作为参数,示例代码如下: ```java import java.util.ArrayList; import java.util.Collections; import java.util.List; public class Main { public static void main(String[] args) { List<Person> personList = new ArrayList<>(); // 添加 Person 对象到 personList 中,省略... // 使用自定义比较器进行排序 Collections.sort(personList, Person.ageNameComparator); // 输出排序结果 for (Person person : personList) { System.out.println(person.getName() + ", " + person.getAge()); } } } ``` 在上面的代码中,我们将 `Person` 对象添加到 `personList` 中,然后使用 `Collections.sort()` 方法对其进行排序排序规则是按照 `Person.ageNameComparator` 自定义比较器进行排序。最后,打印排序结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值