List排序的方式
String的排序,其他基础类型也类似的用法
List<String> list = Lists.newArrayList();
for(int i = 0; i<10; i++){
list.add(UUID.randomUUID()+String.valuefo(i));
}
System.out.println("排序前");
list.forEach(l -> System.out.println(l));
list.sort(Comparator.comparing(String::toString));
System.out.println("list.sort(Comparator.comparing(String::toString))排序升序后");
list.forEach(l -> System.out.println(l));
Collections.sort(list);
System.out.println("Collections.sort()排序升序后");
list.forEach(l -> System.out.println(l));
Collections.reverse(list);
System.out.println("Collections.reverse()排序降序后");
list.forEach(l -> System.out.println(l));
list.sort(Comparator.comparing(String::toString).reversed());
System.out.println("list.sort()排序降序后");
list.forEach(l -> System.out.println(l));
实体类的排序
List<User> list = getUser();
list.sort(Comparator.comparing(User::getName));
/************第二种方式 实体需要实现 Comparabel<User> 接口**************/
// User长这个样纸! 这是model
public Class User implements Comparabal<User>{
private String name;
private Integer age;
private Date createDate;
// 这是比较方法,0表示相等 -1 表示小于 1表示大于
@Override
public int compareTo(User o){
// return this.name.compareTo(o.name)
// return this.createDate.compareTO(o.createDate);
return this.age - o.age;
}
}
/***********************************************************************/
List<User> list = getUser();
Collections.sort(list); // 根据比较方法中的属性取排序
/*************实体类要实现Comparable接口好麻烦,可以不实现吗? 可以!*****************/
// 方式1 升序
Collections.sort(list,new Comparable<User>(){
@Override
public int compareTo(User o1,User o2){
return this.age - o.age;
}
})
// 方式1 降序
Collections.sort(list,new Comparable<User>(){
@Override
public int compareTo(User o1,User o2){
return this.age - o.age;
}
})
// 方式2 升序
list.sort(Comparator.comparaing(User::getAge))
// 方式2 降序
list.sort(Comparator.comparaing(User::getAge).reversed())
/*************有时在复杂的业务场景中需要多字段排序怎么办?*****************/
List<User> list = getUser();
list.sort(Comparator.comparaing(User::getName).themComparaing(User::getAge));