เทียบเคียง -java.lang.Comparable: int compareTo(Object o1)
วัตถุที่เทียบเคียงสามารถเปรียบเทียบตัวเองกับวัตถุอื่นได้ คลาสนั้นต้องใช้อินเทอร์เฟซ java.lang.Comparable เพื่อที่จะสามารถเปรียบเทียบอินสแตนซ์ได้
- สามารถเปรียบเทียบวัตถุปัจจุบันกับวัตถุที่ให้มา
- ด้วยการใช้สิ่งนี้เราสามารถนำไปใช้
only one sort sequence
ตามคุณสมบัติของอินสแตนซ์ EX:Person.id
- คลาสที่กำหนดไว้ล่วงหน้าบางคลาสเช่นสตริง, คลาส Wrapper, วันที่, ปฏิทินได้ใช้อินเทอร์เฟซที่เปรียบเทียบได้
เครื่องเปรียบเทียบ -java.util.Comparator: int compare(Object o1, Object o2)
วัตถุเปรียบเทียบสามารถเปรียบเทียบวัตถุสองชิ้นที่แตกต่างกันได้ คลาสไม่ได้เปรียบเทียบอินสแตนซ์ แต่เป็นอินสแตนซ์ของคลาสอื่น คลาสตัวเปรียบเทียบนี้ต้องใช้อินเทอร์เฟซ java.util.Comparator
- สามารถเปรียบเทียบออบเจ็กต์ประเภทเดียวกันสองชนิด
- ด้วยการใช้สิ่งนี้เราสามารถใช้
many sort sequence
และตั้งชื่อแต่ละรายการตามคุณสมบัติของอินสแตนซ์ EX:Person.id, Person.name, Person.age
- เราสามารถใช้อินเทอร์เฟซตัวเปรียบเทียบกับคลาสที่กำหนดไว้ล่วงหน้าสำหรับการเรียงลำดับแบบกำหนดเอง
ตัวอย่าง:
public class Employee implements Comparable<Employee> {
private int id;
private String name;
private int age;
private long salary;
// Many sort sequences can be created with different names.
public static Comparator<Employee> NameComparator = new Comparator<Employee>() {
@Override
public int compare(Employee e1, Employee e2) {
return e1.getName().compareTo(e2.getName());
}
};
public static Comparator<Employee> idComparator = new Comparator<Employee>() {
@Override
public int compare(Employee e1, Employee e2) {
return Integer.valueOf(e1.getId()).compareTo(Integer.valueOf(e2.getId()));
}
};
public Employee() { }
public Employee(int id, String name, int age, long salary){
this.id = id;
this.name = name;
this.age = age;
this.salary = salary;
}
// setters and getters.
// Only one sort sequence can be created with in the class.
@Override
public int compareTo(Employee e) {
//return Integer.valueOf(this.id).compareTo(Integer.valueOf(e.id));
//return Character.toString(this.name.charAt(0)).compareToIgnoreCase(Character.toString(e.name.charAt(0)));
if (this.id > e.id) {
return 1;
}else if(this.id < e.id){
return -1;
}else {
return Character.toString(this.name.charAt(0)).compareToIgnoreCase(Character.toString(e.name.charAt(0)));
}
}
public static void main(String[] args) {
Employee e1 = new Employee(5, "Yash", 22, 1000);
Employee e2 = new Employee(8, "Tharun", 24, 25000);
List<Employee> list = new ArrayList<Employee>();
list.add(e1);
list.add(e2);
Collections.sort(list); // call @compareTo(o1)
Collections.sort(list, Employee.nameComparator); // call @compare (o1,o2)
Collections.sort(list, Employee.idComparator); // call @compare (o1,o2)
}
}
- สำหรับการเรียงลำดับที่กำหนดเองเราจะใช้ตัวเปรียบเทียบ @compare (o1, o2) สำหรับสถานการณ์อื่น ๆ ที่เราใช้เพื่อเทียบเคียง @compareTo (o1) โดยไม่ต้องเปลี่ยนรหัสหากเราต้องการจัดเรียงมากกว่าหนึ่งฟิลด์จากนั้นเราจะใช้ตัวเปรียบเทียบ
สำหรับJava 8 Lambda: ตัวเปรียบเทียบอ้างถึงโพสต์ของฉัน