日常の作業では、結果セットの何らかのフィルター処理が必要なシナリオが常に存在します。たとえば、サードパーティとの対話後に取得した結果セットを再度並べ替えて重複排除する必要がある場合、結果セットは特定のフィールドに従って重複排除されるか、特定のフィールドによって並べ替えられます。
Java では、重複を削除する場合、Set (順序なし、重複なし) の特性を簡単に考えることができ、TreeSet (順序あり、重複なし) で重複排除のルールを指定することもできます (通常は重複排除後)。は結果セットを昇順で示します)。
ソートというと、さまざまなソート アルゴリズムが簡単に思いつきますが、Java ではコレクションの sort() メソッドなどのソート関数がすでに提供されており、ソート フィールドや昇順、降順を指定することもできます。注文。
ここでもう 1 つ言わせてください、Set の特性 (順序なし、重複なし):
無秩序: 無秩序はランダムではありません, セットに配置された要素は、要素のハッシュ値に応じて位置が決定されるため、
public class CompareTest { public static void main(String[] args) { // 例如:从第三方返回的结果集 // 根据id去重,根据createTime降序排列 String result = "[" + "{ \"id\": 1, \"createTime\": \"2022-12-21 13:23:59\"}" + "{ \"id\": 2, \"createTime\": \"2022-11-11 12:43:01\"}" + "{ \"id\": 1, \"createTime\": \"2022-12-21 11:20:50\"}" + "{ \"id\": 3, \"createTime\": \"2023-01-01 14:30:00\"}" + "]"; JSONArray examList = JSONArray.parseArray(result); System.out.println("初始数据集:" + examList); // 去重,利用set特性 Comparator<JSONObject> comparator = (a, b) -> Integer.compare(a.getIntValue("id"), b.getIntValue("id")); Set<JSONObject> set = new TreeSet<>(comparator); examList.forEach(jo -> set.add((JSONObject) jo)); // 此时的结果是,根据id去重,并且是升序的结果(自然排序) System.out.println("去重结果:" + set); // 此处为了,方便演示Comparable接口的作用,故把JSON映射成实体类,进行实现接口排序,其实sorted也可以使用Comparator排序 List<ExamInfo> collect = set.stream() .map(jo -> JSONObject.toJavaObject(jo, ExamInfo.class)) .sorted() .collect(Collectors.toList()); System.out.println("指定排序结果:" + collect); } }
public class ExamInfo implements Comparable<ExamInfo> { private int id; private String createTime; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getCreateTime() { return createTime; } public void setCreateTime(String createTime) { this.createTime = createTime; } @Override public String toString() { return "ExamInfo{" + "id=" + id + ", createTime='" + createTime + '\'' + '}'; } @Override public int compareTo(ExamInfo o) { // 降序 return o.getCreateTime().compareTo(this.createTime); } }
昇順ソートと降順ソートの問題については、Comparable と Comparator の比較メソッドの戻り値が 0 より大きい場合に交換されます。
パラメータの順序が a, b の場合:a>b、つまり a-b>0 、交換後の順序は a、b なので、b が前、a が後ろになるため、ソート順は 昇順 となり、自然なソートです。 // 升序
Comparator<JSONObject> comparator = (a, b) -> Integer.compare(a.getIntValue("id"), b.getIntValue("id"));
です。 @Override
public int compareTo(ExamInfo o) {
// 降序
return o.getCreateTime().compareTo(this.createTime);
}
3. 違い
コンパレータ |
||
---|---|---|
が含まれるパッケージ関数インターフェイス | は | |
比較メソッド | int CompareTo(T o) | |
使用シナリオ | 比較対象のオブジェクトは自分で変更できます | |
以上がComparable と Comparator を使用して Java で並べ替えを削除する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。