提供的排序程式碼似乎不完整,可能不會產生預期的排序順序。讓我們深入研究使用 Java 8 lambda 的更有效率、更全面的方法。
Java 8 透過提供直覺的 lambda 表達式來簡化清單排序,這些表達式允許簡潔且易於閱讀程式碼。考慮以下內容:
Collections.sort(reportList, Comparator.comparing(Report::getReportKey)
.thenComparing(Report::getStudentNumber)
.thenComparing(Report::getSchool));
這種基於 lambda 的方法對比較過程進行排序,根據指定字段按照 .thenComparing() 方法定義的優先順序對列表進行有效排序。
您提供的原始程式碼連接了報告鍵、學號和學校的字串:
return (record1.getReportKey() record1.getStudentNumber() record1.getSchool())
.compareTo(record2.getReportKey() record2.getStudentNumber() record2.getSchool());
相反,為了正確排序,您應該獨立比較欄位。
這是使用lambda 語法的排序函數的增強版本:
Collections.sort(reportList, (record1, record2) -> {
int reportKeyComparison = record1.getReportKey().compareTo(record2.getReportKey());
if (reportKeyComparison != 0) {
return reportKeyComparison;
}
int studentNumberComparison = record1.getStudentNumber().compareTo(record2.getStudentNumber());
if (studentNumberComparison != 0) {
return studentNumberComparison;
}
return record1.getSchool().compareTo(record2.getSchool());});
此程式碼直接比較各個字段,提供更準確的排序順序。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3