码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 集合排序 List.sort


    一、字符串List排序

    cities是一个字符串数组。注意london的首字母是小写的。

    List<String> cities = Arrays.asList(
            "Milan",
            "london",
            "San Francisco",
            "Tokyo",
            "New Delhi"
    );
    System.out.println(cities);
    //[Milan, london, San Francisco, Tokyo, New Delhi]
    
    cities.sort(String.CASE_INSENSITIVE_ORDER);
    System.out.println(cities);
    //[london, Milan, New Delhi, San Francisco, Tokyo]
    
    cities.sort(Comparator.naturalOrder());
    System.out.println(cities);
    //[Milan, New Delhi, San Francisco, Tokyo, london]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 当使用sort方法,按照String.CASE_INSENSITIVE_ORDER(字母大小写不敏感)的规则排序,结果是:[london, Milan, New Delhi, San Francisco, Tokyo]
    • 如果使用Comparator.naturalOrder()字母自然顺序排序,结果是:[Milan, New Delhi, San Francisco, Tokyo, london]

    同样我们可以把排序器Comparator用在Stream管道流中。

    cities.stream().sorted(Comparator.naturalOrder()).forEach(System.out::println);
    
    //Milan
    //New Delhi
    //San Francisco
    //Tokyo
    //london
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在java 7我们是使用Collections.sort()接受一个数组参数,对数组进行排序。在java 8之后可以直接调用集合类的sort()方法进行排序。

    二、整数类型List排序

    List<Integer> numbers = Arrays.asList(6, 2, 1, 4, 9);
    System.out.println(numbers); //[6, 2, 1, 4, 9]
    
    numbers.sort(Comparator.naturalOrder());  //自然排序
    System.out.println(numbers); //[1, 2, 4, 6, 9]
    
    numbers.sort(Comparator.reverseOrder()); //倒序排序
    System.out.println(numbers);  //[9, 6, 4, 2, 1]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    三、按对象字段对List排序
    @Data
    @AllArgsConstructor
    public class Employee {
       private Integer id;
       private Integer age;   //年龄
       private String gender;  //性别
       private String firstName;  
       private String lastName;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    这个功能就比较有意思了,举个例子大家理解一下。

    Employee e1 = new Employee(1,23,"M","Rick","Beethovan");
    Employee e2 = new Employee(2,13,"F","Martina","Hengis");
    Employee e3 = new Employee(3,43,"M","Ricky","Martin");
    Employee e4 = new Employee(4,26,"M","Jon","Lowman");
    Employee e5 = new Employee(5,19,"F","Cristine","Maria");
    Employee e6 = new Employee(6,15,"M","David","Feezor");
    Employee e7 = new Employee(7,68,"F","Melissa","Roy");
    Employee e8 = new Employee(8,79,"M","Alex","Gussin");
    Employee e9 = new Employee(9,15,"F","Neetu","Singh");
    Employee e10 = new Employee(10,45,"M","Naveen","Jain");
    
    List<Employee> employees = Arrays.asList(e1, e2, e3, e4, e5, e6, e7, e8, e9, e10);
    
    employees.sort(Comparator.comparing(Employee::getAge));
    employees.forEach(System.out::println);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 首先,我们创建了10个Employee对象,然后将它们转换为List
    • 然后重点的的代码使用了函数引用Employee::getAge作为对象的排序字段,即使用员工的年龄作为排序字段
    • 然后调用List的forEach方法将List排序结果打印出来,如下(当然我们重写了Employee的toString方法,不然打印结果没有意义):
    Employee(id=2, age=13, gender=F, firstName=Martina, lastName=Hengis)
    Employee(id=6, age=15, gender=M, firstName=David, lastName=Feezor)
    Employee(id=9, age=15, gender=F, firstName=Neetu, lastName=Singh)
    Employee(id=5, age=19, gender=F, firstName=Cristine, lastName=Maria)
    Employee(id=1, age=23, gender=M, firstName=Rick, lastName=Beethovan)
    Employee(id=4, age=26, gender=M, firstName=Jon, lastName=Lowman)
    Employee(id=3, age=43, gender=M, firstName=Ricky, lastName=Martin)
    Employee(id=10, age=45, gender=M, firstName=Naveen, lastName=Jain)
    Employee(id=7, age=68, gender=F, firstName=Melissa, lastName=Roy)
    Employee(id=8, age=79, gender=M, firstName=Alex, lastName=Gussin)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 如果我们希望List按照年龄age的倒序排序,就使用reversed()方法。如:
    employees.sort(Comparator.comparing(Employee::getAge).reversed());
    
    • 1

    四、Comparator链对List排序

    下面这段代码先是按性别的倒序排序,再按照年龄的倒序排序。

    employees.sort(
            Comparator.comparing(Employee::getGender)
            .thenComparing(Employee::getAge)
            .reversed() // reversed()对上面的getGender、getAge都生效
    );
    employees.forEach(System.out::println);
    
    //都是正序 ,不加reversed
    //都是倒序,最后面加一个reserved
    //先是倒序(加reserved),然后正序
    //先是正序(加reserved),然后倒序(加reserved)负负得正
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    排序结果如下:

    Employee(id=8, age=79, gender=M, firstName=Alex, lastName=Gussin)
    Employee(id=10, age=45, gender=M, firstName=Naveen, lastName=Jain)
    Employee(id=3, age=43, gender=M, firstName=Ricky, lastName=Martin)
    Employee(id=4, age=26, gender=M, firstName=Jon, lastName=Lowman)
    Employee(id=1, age=23, gender=M, firstName=Rick, lastName=Beethovan)
    Employee(id=6, age=15, gender=M, firstName=David, lastName=Feezor)
    Employee(id=7, age=68, gender=F, firstName=Melissa, lastName=Roy)
    Employee(id=5, age=19, gender=F, firstName=Cristine, lastName=Maria)
    Employee(id=9, age=15, gender=F, firstName=Neetu, lastName=Singh)
    Employee(id=2, age=13, gender=F, firstName=Martina, lastName=Hengis)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
  • 相关阅读:
    回归预测 | Matlab实现GWO-ESN基于灰狼算法优化回声状态网络的多输入单输出回归预测
    Pycharm一直打不开,无任何报错
    运放-运算放大器经典应用电路大全-应用电路大全-20种经典电路
    Pytorch模型转ONNX模型
    Ansible的role
    Oracle Primavera Unifier计划管理器(Planning Manager)
    SpringBoot(二)视图
    您的系统存在未授权的Bluetooth适配器,拔除或禁用该设备(蓝牙问题)
    10 种常见的BUG分类
    Golang 环境变量配置 mockgen安装(macOS系统)
  • 原文地址:https://blog.csdn.net/qiuwen_521/article/details/126057277
    • 最新文章
    • 攻防演习之三天拿下官网站群
      数据安全治理学习——前期安全规划和安全管理体系建设
      企业安全 | 企业内一次钓鱼演练准备过程
      内网渗透测试 | Kerberos协议及其部分攻击手法
      0day的产生 | 不懂代码的"代码审计"
      安装scrcpy-client模块av模块异常,环境问题解决方案
      leetcode hot100【LeetCode 279. 完全平方数】java实现
      OpenWrt下安装Mosquitto
      AnatoMask论文汇总
      【AI日记】24.11.01 LangChain、openai api和github copilot
    • 热门文章
    • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
      奉劝各位学弟学妹们,该打造你的技术影响力了!
      五年了,我在 CSDN 的两个一百万。
      Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
      面试官都震惊,你这网络基础可以啊!
      你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
      心情不好的时候,用 Python 画棵樱花树送给自己吧
      通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
      13 万字 C 语言从入门到精通保姆级教程2021 年版
      10行代码集2000张美女图,Python爬虫120例,再上征途
    Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
    正则表达式工具 cron表达式工具 密码生成工具

    京公网安备 11010502049817号