Heim  >  Artikel  >  Java  >  Warum ist der Lambda-Ansatz von Java 8 die beste Möglichkeit, Objekte mit mehreren Feldern zu sortieren?

Warum ist der Lambda-Ansatz von Java 8 die beste Möglichkeit, Objekte mit mehreren Feldern zu sortieren?

Linda Hamilton
Linda HamiltonOriginal
2024-11-01 12:00:04383Durchsuche

  Why is Java 8's Lambda Approach the Best Way to Sort Objects with Multiple Fields?

Verwendung von Java 8-Lambdas (hinzugefügt am 10. April 2019)

Diese Version des Codes nutzt die Vorteile von Java 8-Lambdas das gewünschte Sortierergebnis erzielen:

<code class="java">Collections.sort(reportList, Comparator.comparing(Report::getReportKey)
            .thenComparing(Report::getStudentNumber)
            .thenComparing(Report::getSchool));</code>

Hier kommt es darauf an Verwenden Sie die Methode thenComparing, um eine Kette von Komparatoren zu erstellen. Jeder Komparator in der Kette vergleicht eines der Felder im Report-Objekt. Der resultierende Komparator wird dann zum Sortieren der Liste verwendet.

Dieser Ansatz ist prägnant, leicht zu lesen und typsicher. Es hat auch den Vorteil, dass die Getter langsam ausgewertet werden, was bedeutet, dass die Getter nur dann aufgerufen werden, wenn sie für den Vergleich benötigt werden.

Chaotisch und kompliziert: Sortieren von Hand

Der Originalcode, der manuell sortiert wird, ist ausführlich und fehleranfällig. Es erfordert viel Tipp- und Wartungsaufwand und beim Schreiben der Vergleichslogik können leicht Fehler passieren. So sah es aus:

<code class="java">Collections.sort(reportList, new Comparator<Report>() {

  @Override
  public int compare(Report record1, Report record2) {
    return (record1.getReportKey() + record1.getStudentNumber() + record1.getSchool())                      
        .compareTo(record2.getReportKey() + record2.getStudentNumber() + record2.getSchool());
  }

});</code>

Dieser Ansatz wird nicht zum Sortieren von Objekten mit mehreren Feldern empfohlen.

Der reflektierende Weg: Sortieren mit BeanComparator

Der BeanComparator-Ansatz verwendet Reflektion, um die Felder der Report-Objekte zu vergleichen. Dieser Ansatz ist prägnanter als das manuelle Sortieren, aber auch fehleranfälliger und langsamer. So sah es aus:

<code class="java">ComparatorChain chain = new ComparatorChain(Arrays.asList(
   new BeanComparator("reportKey"),
   new BeanComparator("studentNumber"),
   new BeanComparator("school")));

Collections.sort(reportList, chain);  </code>

Dieser Ansatz wird nicht zum Sortieren von Objekten mit mehreren Feldern empfohlen.

Anfahrt: Sortieren mit der CompareChain von Google Guava

Der Google Guava CompareChain-Ansatz ähnelt dem BeanComparator-Ansatz, ist jedoch flexibler und schneller. So sah es aus:

<code class="java">Collections.sort(reportList, new Comparator<Report>() {  

  @Override  
  public int compare(Report p1, Report p2) {  
    return ComparisonChain.start().compare(p1.getReportKey(), p2.getReportKey()).compare(p1.getStudentNumber(), p2.getStudentNumber()).compare(p1.getSchool(), p2.getSchool()).result();  
  }  
});  </code>

Dieser Ansatz ist eine gute Wahl zum Sortieren von Objekten mit mehreren Feldern, aber er ist nicht so prägnant wie der Java 8-Lambda-Ansatz.

Der Apache Commons CompareToBuilder-Ansatz ähnelt dem von Google Der Guava-Vergleichskettenansatz ist jedoch weniger flexibel. So sah es aus:

<code class="java">Collections.sort(reportList, new Comparator<Report>() {  

  @Override  
  public int compare(Report p1, Report p2) {  
    return new CompareToBuilder().append(p1.getReportKey(), p2.getReportKey()).append(p1.getStudentNumber(), p2.getStudentNumber()).append(p1.getSchool(), p2.getSchool()).toComparison();  
  }  
});  </code>

Dieser Ansatz ist eine gute Wahl zum Sortieren von Objekten mit mehreren Feldern, aber er ist nicht so prägnant wie der Java 8-Lambda-Ansatz.

Letztendlich hängt der beste Ansatz zum Sortieren von Objekten mit mehreren Feldern von den spezifischen Anforderungen der Anwendung ab. Der Java 8-Lambda-Ansatz ist der prägnanteste und typsicherste Ansatz, erfordert jedoch Java 8 oder höher. Der Google Guava CompareChain-Ansatz ist eine gute Wahl für Anwendungen, die mehr Flexibilität als der Java 8-Lambda-Ansatz benötigen, aber er ist nicht so prägnant. Der Apache Commons CompareToBuilder-Ansatz ist eine gute Wahl für Anwendungen, die weniger Flexibilität benötigen als der Google Guava CompareChain-Ansatz, ist aber nicht so prägnant.

Das obige ist der detaillierte Inhalt vonWarum ist der Lambda-Ansatz von Java 8 die beste Möglichkeit, Objekte mit mehreren Feldern zu sortieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn