提供的排序代码似乎不完整,可能不会产生预期的排序顺序。让我们深入研究使用 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