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());
相关推荐
郭二哈17 分钟前
C++——list
开发语言·c++·list
杨荧18 分钟前
【JAVA开源】基于Vue和SpringBoot的洗衣店订单管理系统
java·开发语言·vue.js·spring boot·spring cloud·开源
陈逸轩*^_^*35 分钟前
Java 网络编程基础
java·网络·计算机网络
这孩子叫逆1 小时前
Spring Boot项目的创建与使用
java·spring boot·后端
星星法术嗲人1 小时前
【Java】—— 集合框架:Collections工具类的使用
java·开发语言
Ljubim.te1 小时前
软件设计师——数据结构
数据结构·笔记
一丝晨光1 小时前
C++、Ruby和JavaScript
java·开发语言·javascript·c++·python·c·ruby
天上掉下来个程小白1 小时前
Stream流的中间方法
java·开发语言·windows
xujinwei_gingko1 小时前
JAVA基础面试题汇总(持续更新)
java·开发语言
liuyang-neu1 小时前
力扣 简单 110.平衡二叉树
java·算法·leetcode·深度优先