java 集合排序_Java8之集合排序

1,List>格式

这种排序方式有bug,如果item.get(sortField)是数字,toString()之后排序是不正确的

//排序

Comparator> comparator = Comparator.comparing(item ->item.get(sortField).toString());if (Constant.SORT_TYPE_ASC ==sortType){//升序

resourceList.sort(comparator);

}else{

resourceList.sort(comparator.reversed());

}

2,List格式

resultList.sort(Comparator.comparing(MetaDataModel::getOrder));

dictVoList.sort(Comparator.comparingInt(DictVo::getOrder));

3,Set格式

public static void test2(){

Set students = new HashSet<>();

Student student1 = new Student(1,"李四",1);

Student student2 = new Student(2,"张三",3);

Student student3 = new Student(3,"王麻",2);

students.add(student1);

students.add(student2);

students.add(student3);

List studentList1 = new ArrayList<>(students);

studentList1.sort(Comparator.comparing(Student::getAge));

System.out.println(studentList1);

}

4,Set格式

public static voidtest3(){

Set sets = new HashSet<>();

sets.add("aa");

sets.add("ee");

sets.add("cc");//倒序

Set treeSetDesc = new TreeSet<>((o1, o2) ->o2.compareTo(o1));

treeSetDesc.addAll(sets);

System.out.println(treeSetDesc);//升序

Set treeSetAsc = new TreeSet<>((o1, o2) ->o1.compareTo(o2));

treeSetAsc.addAll(sets);

System.out.println(treeSetAsc);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值