ArrayList中放的是一个对象,如何同时根据对象中的三个字段对List进行排序

java 复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;

public class YourObject {
    private int field1;
    private String field2;
    private double field3;

    // 构造函数和其他代码

    public int getField1() {
        return field1;
    }

    public String getField2() {
        return field2;
    }

    public double getField3() {
        return field3;
    }
}

public class Main {
    public static void main(String[] args) {
        // 创建包含对象的ArrayList
        ArrayList<YourObject> list = new ArrayList<>();

        // 添加对象到ArrayList

        // 使用Comparator对ArrayList进行排序
        Collections.sort(list, Comparator
                .comparingInt(YourObject::getField1)
                .thenComparing(YourObject::getField2)
                .thenComparingDouble(YourObject::getField3));

    }
}

Comparator.comparingInt(YourObject::getField1):这是创建一个比较器,通过 getField1 方法比较对象的整型字段 field1。这个比较器首先按照 field1 进行升序排序。

.thenComparing(YourObject::getField2):使用 thenComparing 方法,如果 field1 相等,则按照对象的字符串字段 field2 进行升序排序。对date类型的数据进行排序也是用这个方法。

.thenComparingDouble(YourObject::getField3):再次使用 thenComparing 方法,如果 field1 和 field2 相等,则按照对象的双精度字段 field3 进行升序排序。

这个排序默认的是升序,如果是想要降序的话在每个 comparing 或 thenComparing 方法后面加上 .reversed() 将会反转排序顺序,使其按照降序排列。

java 复制代码
Collections.sort(list, Comparator
        .comparingInt(YourObject::getField1).reversed()
        .thenComparing(YourObject::getField2).reversed()
        .thenComparingDouble(YourObject::getField3).reversed());
相关推荐
醉城夜风~10 分钟前
[数据结构]堆详解
开发语言·数据结构
苏言の狗15 分钟前
小R的并集大小期望计算 | 蛮力
数据结构·算法
橘颂TA23 分钟前
每日一练之链表的回文结构
数据结构·链表
刃神太酷啦26 分钟前
数据结构(蓝桥杯常考点)
数据结构·c++·蓝桥杯c++组
用户611881615196229 分钟前
Java基础面试题
java
DavidSoCool1 小时前
Elasticsearch Java API Client [8.17] 使用
java·大数据·elasticsearch
无世世1 小时前
【Java从入门到起飞】面向对象编程(高级)
java·开发语言
Vic101011 小时前
Mac如何查看 IDEA 的日志文件
java·macos·intellij-idea
陈逸轩*^_^*1 小时前
idea打不开,idea打不开,Error occurred during initialization of VM
java·ide·intellij-idea
冠位观测者1 小时前
【Leetcode 每日一题 - 补卡】2070. 每一个查询的最大美丽值
数据结构·算法·leetcode