理解比较器
在 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中文网其他相关文章!