返回顶部
首页 > 资讯 > 后端开发 > JAVA >Java8新特性 | List多字段排序(含示例代码)
  • 749
分享到

Java8新特性 | List多字段排序(含示例代码)

java算法开发语言 2023-09-13 06:09:25 749人浏览 独家记忆
摘要

可以利用 List 的 sort 方法进行排序,Comparator.comparing 可以指定排序字段,thenComparing 可以继续指定其他的排序字段。 默认使用正序排列,如果想倒序可

可以利用 List 的 sort 方法进行排序Comparator.comparing 可以指定排序字段,thenComparing 可以继续指定其他的排序字段。
默认使用正序排列,如果想倒序可以使用 Comparator.reverseOrder() 指定。

下面是示例代码
创建一个内部类 SortTest

@Getter@Setter@AllArgsConstructorstatic class SortTest {    private String name;    private int a;    private int b;    private int c;}

添加main方法,声明一个List,并往其中添加数据,再按规则进行排序(先按a倒序排列、再按b倒序排列、最后按c正序排列),最后输出。

public static void main(String[] args) {    // 测试List多属性排序    List<SortTest> list = new ArrayList<>();    list.add(new SortTest("S1", 7, 3, 7));    list.add(new SortTest("S2", 9, 5, 5));    list.add(new SortTest("S3", 5, 7, 4));    list.add(new SortTest("S4", 1, 5, 4));    list.add(new SortTest("S5", 4, 5, 4));    list.add(new SortTest("S6", 5, 6, 1));    list.add(new SortTest("S7", 5, 7, 1));    list.add(new SortTest("S8", 5, 3, 7));    list.add(new SortTest("S9", 5, 7, 7));    // 先按a倒序排列、再按b倒序排列、最后按c正序排列    list.sort(Comparator.comparing(SortTest::getA, Comparator.reverseOrder())            .thenComparing(SortTest::getB, Comparator.reverseOrder())            .thenComparing(SortTest::getC));    for (SortTest sortTest : list) {        System.out.println(sortTest.getName() + "\t" + sortTest.getA() + "\t" + sortTest.getB() + "\t" + sortTest.getC());    }}

输出结果:从输出结果也可以看出,List 确定是按照我们定义的规则进行排序的。

S2955S1737S7571S3574S9577S6561S8537S5454S4154

至此 Java8 的 List 多字段排序介绍完成。

来源地址:https://blog.csdn.net/gozhuyinglong/article/details/128255051

--结束END--

本文标题: Java8新特性 | List多字段排序(含示例代码)

本文链接: https://lsjlt.com/news/405527.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作