Heim >Java >javaLernprogramm >Warum ist der Lambda-Ansatz von Java 8 die beste Möglichkeit, Objekte mit mehreren Feldern zu sortieren?
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.
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 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.
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!