日常小记录:
今天写项目的时候,遇到一种情形,需要根据集合中对象的某一个属性进行排序。
话不多说,直接安排demo。
step1:创建User对象类
@Data
public class User{
private long id;
private String name;
private int age;
private String pwd;
public User() {
}
public User(long id, String name, int age, String pwd) {
super();
this.id = id;
this.name = name;
this.age = age;
this.pwd = pwd;
}
}
step2:然后初始化一个对象集合。
public List<User> getUserList() {
List<User> list = new ArrayList();
list.add(new User(1,"lmh",20,"123456"));
list.add(new User(2,"lmh",23,"123456"));
list.add(new User(3,"lmh",10,"123456"));
list.add(new User(4,"lmh",14,"123456"));
list.add(new User(5,"lmh",30,"123456"));
list.add(new User(6,"lmh",15,"123456"));
return list;
}
step3:用java8 对集合根据user的age属性进行降序、升序排序。
public List<User> sortDescByAge (){
List<User> list = this.getUserList();
log.info("排序之前的集合是:"+list);
list.forEach(System.out::println);
//根据年龄降序排序
list.sort(Comparator.comparing(User::getAge).reversed());
log.info("根据年龄降序之后的集合是:"+list);
list.forEach(System.out::println);
//根据年龄升序排序
list.sort(Comparator.comparing(User::getAge));
log.info("根据年龄升序之后的集合是:"+list);
list.forEach(System.out::println);
return list;
}
step4:启动项目。
如果项目中用的是java7的话,可以重写Comparable 的compareTo()方法。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)