首页 > Java > java教程 > 如何使用比较器对 Java 中的自定义对象列表进行正确排序?

如何使用比较器对 Java 中的自定义对象列表进行正确排序?

DDD
发布: 2024-12-25 06:16:09
原创
539 人浏览过

How Can I Correctly Sort a List of Custom Objects in Java Using Comparators?

在 Java 中使用比较器对对象进行排序

理解比较器

在 Java 中,比较器是定义对象应该如何排序的接口进行比较以进行排序。实现比较器允许您定义偏离 Comparable 接口提供的自然顺序的自定义排序行为。

错误分析

您的代码遇到异常,因为您'正在尝试对包含 People 对象的 ArrayList 进行排序,而不实现 Comparable 或 Comparator 接口。 People 类中的比较方法不正确,因为它应该比较 People 类的实例,而不是 Integer 包装对象。

解决方案

要解决此问题,您可以实现一个 Comparator,根据 People 对象的 ID 进行比较,如下所示:

import java.util.Comparator;

public class PeopleComparator implements Comparator<People> {

    @Override
    public int compare(People p1, People p2) {
        return p1.getId() - p2.getId();
    }
}
登录后复制

在您的 TestPeople 类中,使用PeopleComparator 对 peps 列表进行排序:

import java.util.ArrayList;
import java.util.Collections;

public class TestPeople {

    public static void main(String[] args) {
        ArrayList<People> peps = new ArrayList<>();

        peps.add(new People(123, "M", 14.25));
        // ...

        Collections.sort(peps, new PeopleComparator());

        for (People person : peps) {
            System.out.println(person);
        }
    }
}
登录后复制

替代方法

Java 提供了一种使用 Comparator 类实现自定义排序的替代方法,可以直接赋值到排序方法,而不需要单独的类。例如:

Collections.sort(peps, new Comparator<People>() {

    @Override
    public int compare(People p1, People p2) {
        return p1.getId() - p2.getId();
    }
});
登录后复制

此外,您可以使用新的 lambda 表达式语法(Java 8 )来简化比较器实现:

Collections.sort(peps, (p1, p2) -> p1.getId() - p2.getId());
登录后复制

以上是如何使用比较器对 Java 中的自定义对象列表进行正确排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板