共計 1004 個字符,預計需要花費 3 分鐘才能閱讀完成。
要實現對自定義類型排序,需要滿足兩個條件:
-
自定義類型需要實現
Comparable
接口,即實現compareTo
方法。該方法定義了自定義類型的排序規則。 -
使用排序算法對自定義類型的集合進行排序。
以下是示例代碼:
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
class Person implements Comparable<Person> {private String name;
private int age;
public Person(String name, int age) {this.name = name;
this.age = age;
}
public String getName() {return name;
}
public int getAge() {return age;
}
@Override
public int compareTo(Person p) {// 根據年齡進行排序
if (this.age < p.getAge()) {return -1;
} else if (this.age > p.getAge()) {return 1;
} else {return 0;
}
}
}
public class Main {public static void main(String[] args) {List<Person> personList = new ArrayList<>();
personList.add(new Person("Alice", 25));
personList.add(new Person("Bob", 30));
personList.add(new Person("Charlie", 20));
// 使用 Collections.sort 方法對集合進行排序
Collections.sort(personList);
for (Person p : personList) {System.out.println(p.getName() + " - " + p.getAge());
}
}
}
以上代碼中,Person
類實現了 Comparable<Person>
接口,并重寫了 compareTo
方法。在 main
方法中,首先創建了一個 Person
類型的集合 personList
,然后使用 Collections.sort
方法對該集合進行排序。最后,通過遍歷集合,打印出排序后的結果。
丸趣 TV 網 – 提供最優質的資源集合!
正文完