首页 >Java >java教程 >如何按多个字段对 Java 对象数组进行排序?

如何按多个字段对 Java 对象数组进行排序?

DDD
DDD原创
2024-12-23 04:39:47407浏览

How Can I Sort a Java Array of Objects by Multiple Fields?

在 Java 中按多个字段对数组进行排序

使用对象数组时,经常需要根据多个条件对它们进行排序。在本例中,任务是按名称字母顺序然后按年龄对 Person 对象数组进行排序。

解决方案 1:使用自定义比较器

一种方法是使用自定义比较器来定义排序标准。此类实现 Comparator 接口并重写 Compare 方法来指定所需的排序逻辑。

下面是演示此方法的代码片段:

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;
            }

            Integer x1 = ((Person) o1).getAge();
            Integer x2 = ((Person) o2).getAge();
            return x1.compareTo(x2);
        }
    });
}

此比较器首先比较Person 对象,如果相等,则比较年龄。

方法: Collections.sort

算法:归并排序(Arrays.sort使用)

时间复杂度: O(n log n)

好处:允许灵活排序标准。

以上是如何按多个字段对 Java 对象数组进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn