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