[英]Collectors groupingBy insertion, ascending and descending order - java8
Sample Data 样本数据
List<Test> tests = new ArrayList();
Test test3 = new Test();
test3.setName("FELLOW");
test3.setDescription("DESC FELLOW 1");
tests.add(test3);
Test test4 = new Test();
test4.setName("FELLOW");
test4.setDescription("DESC FELLOW 2");
tests.add(test4);
Test test = new Test();
test.setName("HELLO");
test.setDescription("DESC Hello 1");
tests.add(test);
Test test1 = new Test();
test1.setName("HELLO");
test1.setDescription("DESC Hello 2");
tests.add(test1);
Test test2 = new Test();
test2.setName("HELLO");
test2.setDescription("DESC Hello 3");
tests.add(test2);
Test test5 = new Test();
test5.setName("ABC");
test5.setDescription("DESC FELLOW 3");
tests.add(test5);
Test test6 = new Test();
test6.setName("ABC");
test6.setDescription("DESC ABC 1");
tests.add(test6);
To get data in insertion order, I used LinkedHashMap 为了按插入顺序获取数据,我使用了LinkedHashMap
Map<String, List<Test>> insertionOrder = tests.stream().collect(Collectors.groupingBy(Test::getName, LinkedHashMap::new, Collectors.toList()));
result: 结果:
FELLOW,
HELLO
ABC
To get data in ascending order, I used TreeMap 为了按升序获取数据,我使用了TreeMap
Map<String, List<Test>> ascendingOrder = tests.stream().collect(Collectors.groupingBy(Test::getName, TreeMap::new, Collectors.toList()));
result: 结果:
ABC,
FELLOW
HELLO
How to get Map in descending order ? 如何按降序获取Map? for example ? 例如 ?
HELLO,
FELLOW
ABC
Pass a Comparator
to the TreeMap
constructor. 将Comparator
传递给TreeMap
构造函数。 For example: 例如:
Map<String, List<Test>> descendingOrder =
tests.stream()
.collect(Collectors.groupingBy(Test::getName,
() -> new TreeMap(Comparator.naturalOrder().reversed()),
Collectors.toList()));
Or: 要么:
Map<String, List<Test>> descendingOrder =
tests.stream()
.collect(Collectors.groupingBy(Test::getName,
() -> new TreeMap<>(Collections.reverseOrder()),
Collectors.toList()));
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.