在 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中文网其他相关文章!