给对象中的属性做指定顺序的排序
在项目当中我们的对象一般都会有个状态,我们默认查询都只能根据状态的数值来进行排序,但是在实际业务中这样的排序对我们意义不是特别大。
小案例
我们要根据 status 进行排序 ,排序的顺序为 3、1、2、4
@Test
public void specifiedOrderSort() {
UserEntity a1 = new UserEntity().setId(1).setStatus(1).setName("A1");
UserEntity a2 = new UserEntity().setId(2).setStatus(2).setName("A2");
UserEntity a3 = new UserEntity().setId(3).setStatus(3).setName("A3");
UserEntity a4 = new UserEntity().setId(4).setStatus(4).setName("A4");
UserEntity a5 = new UserEntity().setId(5).setStatus(3).setName("A5");
UserEntity a6 = new UserEntity().setId(6).setStatus(2).setName("A6");
UserEntity a7 = new UserEntity().setId(7).setStatus(4).setName("A7");
List<UserEntity> userList = Arrays.asList(a1, a2, a3, a4, a5, a6, a7);
// Map 用来存储顺序
Map<Integer, Integer> ruleUpper = new HashMap<>();
ruleUpper.put(3, 1);
ruleUpper.put(1, 2);
ruleUpper.put(2, 3);
ruleUpper.put(4, 4);
userList.sort(new Comparator<UserEntity>() {
@Override
public int compare(UserEntity o1, UserEntity o2) {
return ruleUpper.getOrDefault(o1.getStatus(), Integer.MAX_VALUE) - ruleUpper.getOrDefault(o2.getStatus(), Integer.MAX_VALUE);
}
});
userList.forEach(System.out::println);
}
结果如下:
UserEntity(id=3, code=null, status=3, name=A3, sex=null, birthday=null, pingList=null)
UserEntity(id=5, code=null, status=3, name=A5, sex=null, birthday=null, pingList=null)
UserEntity(id=1, code=null, status=1, name=A1, sex=null, birthday=null, pingList=null)
UserEntity(id=2, code=null, status=2, name=A2, sex=null, birthday=null, pingList=null)
UserEntity(id=6, code=null, status=2, name=A6, sex=null, birthday=null, pingList=null)
UserEntity(id=4, code=null, status=4, name=A4, sex=null, birthday=null, pingList=null)
UserEntity(id=7, code=null, status=4, name=A7, sex=null, birthday=null, pingList=null)