提供された並べ替えコードは不完全であるため、期待どおりの並べ替え順序が生成されない可能性があります。 Java 8 ラムダを使用した、より効率的で包括的なアプローチを見てみましょう。
Java 8 は、簡潔で読みやすい直感的なラムダ式を提供することで、リストの並べ替えを簡素化します。コード。次の点を考慮してください:
<code class="java">Collections.sort(reportList, Comparator.comparing(Report::getReportKey) .thenComparing(Report::getStudentNumber) .thenComparing(Report::getSchool));</code>
このラムダベースのアプローチは比較プロセスを順序付けし、.thenComparing() メソッドで定義された優先順位で指定されたフィールドに基づいてリストを効果的に並べ替えます。
指定した元のコードは、レポート キー、学生番号、学校の文字列を連結します:
<code class="java">return (record1.getReportKey() + record1.getStudentNumber() + record1.getSchool()) .compareTo(record2.getReportKey() + record2.getStudentNumber() + record2.getSchool());</code>
代わりに、適切に並べ替えるために、フィールドを比較する必要があります。
ラムダ構文を使用したソート関数の拡張バージョンを次に示します。
<code class="java">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());});</code>
このコードは、個々のフィールドを直接比較し、より多くの結果を提供します。正確な並べ替え順序。
以上がJava 8 Lambda を使用して複数のフィールドでコレクションを効率的に並べ替える方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。