评论

收藏

[Java] 利用stream sorted进行降序排序

编程语言 编程语言 发布于:2021-09-11 21:09 | 阅读数:748 | 评论:0

这篇文章主要介绍了利用stream sorted进行降序排序,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
根据value值的大小进行降序排序,并进行截取。
public static void main(String[] args) {
  List<Map<String, Object>> list = Lists.newArrayList();
  Map<String, Object> map = Maps.newHashMap();
  map.put("id", 1);
  map.put("value", 20);
  list.add(map);
  map = Maps.newHashMap();
  map.put("id", 2);
  map.put("value", 80);
  list.add(map);
  map = Maps.newHashMap();
  map.put("id", 3);
  map.put("value", 21);
  list.add(map);
  map = Maps.newHashMap();
  map.put("id", 4);
  map.put("value", 28);
  list.add(map);
  System.out.println("原始数据:"+list);
  //根据value进行排序 得到升序排列
  list.sort(Comparator.comparing(h -> ConvertUtil.obj2Integer(h.get("value"))));
  //颠倒排序,变为降序排列
  Collections.reverse(list);
  //截取前3个
  System.out.println("结果"+list.subList(0, 3));
 }
使用1.8 stream处理
List<Map<String, Object>>result = list.stream().sorted((h1, h2) -> 
//降序
ConvertUtil.obj2Integer(h2.get("value")).compareTo(ConvertUtil .obj2Integer(h1.get("value"))))
 //前3个
  .limit(3)
  //终止流
  .collect(Collectors.toList());
 System.out.println("流结果"+result );
运行结果:
原始数据:
[{id=1, value=20}, {id=2, value=80}, {id=3, value=21}, {id=4, value=28}]
结果
[{id=2, value=80}, {id=4, value=28}, {id=3, value=21}]
补充:Java8Stream流的sorted()排序===使用Comparator排序
sorted()方法排序,一个是Comparable(自然排序),一个是Comparator接口,像Integer、String等这些基本类型的包装类已经实现了Comparable接口,
Comparable接口======》java.lang包下的
方法CompareTo(Object o),除了基本类型包装类外,一些常用的pojo类要使用CompareTo(Object o)排序,就要实现Comparable接口,在pojo类里重写compareTo()方法
Comparator接口======》java.util包下的
方法compare(Object a,Object b)
关于Comparable和Comparator接口
Sorted排序一共有两种,自然排序和Comparator接口的排序,
使用sorted()排序
1、简单List<Integer> 排序=====》
package com.it.test;
import java.util.ArrayList; 
import java.util.List;
import java.util.stream.Collectors; 
public class StreamTest {
 public static void main(String[] args) {
  List<Integer> integers = new ArrayList<>();
  integers.add(9);
  integers.add(2);
  integers.add(0);
  integers.add(4);
  integers.add(8);
  List<Integer> collect = integers.stream().sorted().collect(Collectors.toList()); //自然排序
 }
}
结果
DSC0000.jpg

2、简单List<String>排序
package com.it.test;
import java.util.ArrayList; 
import java.util.List;
import java.util.stream.Collectors; 
public class StreamTest {
 public static void main(String[] args) {
  List<String> strings = new ArrayList<>();
  strings.add("aa");
  strings.add("b");
  strings.add("aac");
  strings.add("bb");
  strings.add("abb");
  List<String> collect1 = strings.stream().sorted().collect(Collectors.toList());
  System.out.println(collect1.toString());
 }
}
结果
DSC0001.jpg

3、复杂实体对象pojo排序
使用Comparator排序
Person.java
package com.it.pojo; 
import java.util.Comparator;
import java.util.Objects; 
@Data
@NoArgsConstructor
@ToString
public class Person {
 private String name;
 private Integer age;
}
test.java===>先只根据年龄排序,后先根据年龄排序,再根据姓名排序,都升序
package com.it.test;
import java.util.ArrayList; 
import java.util.List;
import com.it.pojo.Person; 
import java.util.Comparator;
import java.util.stream.Collectors; 
public class StreamTest {
 public static void main(String[] args) {
  Person person1 = new Person();
  person1.setAge(21);
  person1.setName("21");
 
  Person person2 = new Person();
  person2.setAge(19);
  person2.setName("19");
 
  Person person3 = new Person();
  person3.setAge(19);
  person3.setName("20");
 
  Person person4 = new Person();
  person4.setAge(20);
  person4.setName("20");
 
  Person person5 = new Person();
  person5.setAge(19);
  person5.setName("18");
  
  List<Person> people = new ArrayList<>();
  people.add(person1);
  people.add(person2);
  people.add(person3);
  people.add(person4);
  people.add(person5);
  
  List<Person> collect1 = people.stream().sorted((Comparator.comparing(Person::getAge))).collect(Collectors.toList());//只根据年龄排序,升序
  System.out.println(collect2);
  
   List<Person> collect2 = people.stream().sorted((Comparator.comparing(Person::getAge)).reversed()).collect(Collectors.toList());//只根据年龄排序,降序
  System.out.println(collect2);
  
  List<Person> collect3 = people.stream().sorted((Comparator.comparing(Person::getAge)).thenComparing(Comparator.comparing(Person::getName))).collect(Collectors.toList());//先根据年龄进行排序,遇见相同的,然后根据姓名进行排序,都升序
  System.out.println(collect3);
 
   List<Person> collect4 = people.stream().sorted((Comparator.comparing(Person::getAge)).thenComparing(Comparator.comparing(Person::getName)).reversed()).collect(Collectors.toList());/先根据年龄进行排序,遇见相同的,然后根据姓名进行排序,降序【都降序】
  System.out.println(collect4);
 
  List<Person> collect5 = people.stream().sorted(Comparator.comparing(Person::getAge).reversed().thenComparing(Comparator.comparing(Person::getName)).reversed()).collect(Collectors.toList());//年龄升序,姓名降序
  System.out.println(collect5);
  
  List<Person> collect6 = people.stream().sorted(Comparator.comparing(Person::getAge).reversed().thenComparing(Comparator.comparing(Person::getName))).collect(Collectors.toList());//根据年龄降序,姓名升序
  System.out.println(collect6);
 }
}
结果
只根据年龄进行排序的,默认是升序
DSC0002.jpg

根据年龄降序
DSC0003.jpg

先根据年龄,后根据姓名排序的,默认都是升序
DSC0004.jpg

根据年龄和性别,先根据年龄,年龄相同根据性别,只在最后一个comparing上写reversed,两个排序都是降序【根据年龄降序,姓名降序】
DSC0005.jpg

根据年龄升序,年龄相同,根据姓名降序
DSC0006.jpg

总结
先这么着吧
以上为个人经验,希望能给大家一个参考,也希望大家多多支持CodeAE代码之家。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/banjw_129/article/details/83585135

关注下面的标签,发现更多相似文章