Java实现List数据的自定义排序

该博客演示了如何在Java中根据多个字段对对象列表进行排序。首先,通过`Collections.sort()`方法和自定义`Comparator`按年龄字段对`User`对象列表进行排序。接着,博主介绍了如何进一步实现按姓名和年龄双重排序,先按姓名字母顺序排序,再按年龄排序。示例代码清晰地展示了这种复合排序的实现方式。

比如按照User的年龄字段进行排序,

package com.allen;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

/**
 * @author :jhys
 * @date :Created in 2021/6/13 23:54
 * @Description :
 */
public class User {
    private String name;
    private int age;
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public User(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public User() {
        super();
    }
    @Override
    public String toString() {
        return "User [name=" + name + ", age=" + age + "]";
    }

    public static void main(String[] args) {
        List<User> list = new ArrayList<>();
        list.add(new User("张三",18));
        list.add(new User("诸葛亮",69));
        list.add(new User("孙悟空",500));
        list.add(new User("周杰伦",45));
        list.add(new User("郭德纲",60));
        list.add(new User("秦始皇",5000));
        System.out.println("排序前:");
        System.out.println(list);
        Collections.sort(list, new Comparator<User>() {
            @Override
            public int compare(User o1, User o2) {
                int age1 = o1.getAge();
                int age2 = o2.getAge();
                if (age1 == age2) {
                    return 0;
                } else {
                    return age1 > age2 ? 1 : -1;
                }
            }
        });
        System.out.println("排序后:");
        System.out.println(list);

    }
}

运行结果:

补充:

如何在Java中按两个字段排序?

比如我有一系列的对象person ( int age; String name;)...

如何排序这个数组,先在按字母顺序排序,然后按年龄排序?

private static void order(List<Person> persons) {

    Collections.sort(persons, new Comparator() {

        public int compare(Object o1, Object o2) {

            String x1 = ((Person) o1).getName();
            String x2 = ((Person) o2).getName();
            int sComp = x1.compareTo(x2);

            if (sComp != 0) {
               return sComp;
            } else {
               Integer x1 = ((Person) o1).getAge();
               Integer x2 = ((Person) o2).getAge();
               return x1.compareTo(x2);
            }
    }});
}

List<Persons>现在按名字排序,然后按年龄排序。

String.compareTo“按字典顺序比较两个字符串”

Collections.sort是本地集合库中的静态方法。它执行实际的排序,您只需要提供一个比较器,它定义了如何比较列表中的两个元素。

内容概要:本文围绕可变桨叶四旋翼无人机的规范控制与点对点运动模拟展开,重点研究优化推力分配策略在翻转动作中的应用与性能比较。通过Matlab代码实现,构建了四旋翼动力学模型,并设计了多种控制算法以实现精确的姿态调整与轨迹跟踪。研究对比了不同推力分配方案在执行高机动性翻转动作时的稳定性、能耗效率与响应速度,旨在提升无人机在复杂飞行任务中的动态性能与控制精度。该仿真研究为无人机飞控系统的设计与优化提供了理论依据和技术支持。; 适合人群:具备一定自动控制理论基础和Matlab编程能力,从事无人机控制、飞行器动力学或机器人系统研究的科研人员及研究生。; 使用场景及目标:① 实现四旋翼无人机在三维空间中的精确点对点运动控制;② 对比分析不同推力分配策略在执行翻转等高难度动作时的控制效果与能耗表现,优化飞行性能;③ 为无人机自主飞行、特技飞行及复杂环境下的机动控制提供算法验证平台。; 阅读建议:此资源以Matlab仿真为核心,建议读者结合相关控制理论知识,深入理解代码实现细节,重点关注动力学建模、控制律设计与推力分配模块。在学习过程中,应动手调试参数,复现文中翻转动作的仿真结果,并尝试拓展至其他复杂飞行任务,以加深对无人机控制机理的理解。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值