Home > Java > javaTutorial > body text

Detailed description of the differences between Java Comparator Vs Comparable

黄舟
Release: 2017-03-14 11:56:00
Original
1780 people have browsed it


1. Similarities between Comparator and Comparable

  • Comparable & Comparator are both used to compare and sort elements in a collection;

  • Comparable & Comparator are both java interfaces, Comparable is located under the package java.lang, and Comparator is located under the package java.util;

  • If the custom class implements one of the two, you can compare the sizes.


2. The difference between Comparator and Comparable

  • Comparable is generally defined inside the class, while Comparator is generally defined outside the class ;

  • To implement the Comparable interface, you need to rewrite its compareTo method, and to implement the Comparator interface, you need to rewrite its compare method Method;


Implement Comparable interface method:

public class Person implements Comparable<Person> {

     private String name;     private int age;     @Override
     public int compareTo(Person another) {          int i = 0;
          i = name.compareTo(another.name);     // 使用String的compareTo方法
          if(i == 0) {      // 如果名字一样,比较年龄, 返回比较年龄结果
               return age - another.age;
          } else {               return i;    // 名字不一样, 返回比较名字的结果.
          }
     }
}
Copy after login

At this time, We can use Collections.sort( personList ) to sort.


Implement the Comparator interface method:

public class Person{
     private String name;     private int age
}
Copy after login
public class PersonComparator implements Comparator<Person> { 
     public int compare(Person one, Person another) {          int i = 0;
          i = one.name.compareTo(another.name);     // 使用String的compareTo方法
          if(i == 0) {      // 如果名字一样,比较年龄,返回比较年龄结果
               return one.age - another.age;
          } else {               return i;    // 名字不一样, 返回比较名字的结果.
          }
     }
}
Copy after login

At this time, we can use Collections.sort(personList,new PersonComparator()) for sorting.


3. Summary

  • Using Comparable is relatively simple. As long as the object that implements the Comparable interface becomes An object that can be compared, but requires modifying the source code, and doing so will lead to relatively high code coupling, which will seriously affect the scalability of the code;

  • The advantage of using Comparator is There is no need to modify the source code, and the code will not be strongly coupled , but implement another comparator. When a custom object needs to be compared, the size can be compared by passing the comparator and the object together;

So, from the perspective of code scalability, it would be better to implement the Comparator interface to sort the elements in the container.

Look at the following example:

public class HonorPerson extends Person{
     private String name;     private int age;     private STring degree;
}
Copy after login

 Here, the HonorPerson class cannot implement the Comparable interface again, because generics do not allow this, in other words In other words, the HonorPerson class can only use the comparison method of the Person class, and cannot define its own comparison method.

public class PersonComparator implements Comparator<Person>{}
Copy after login
public class HonorPersonComparator implements Comparator<HonorPerson>{}
Copy after login

 Here, HonorPerson and Person each have their own comparison methods, which do not affect or conflict with each other.

The above is the detailed content of Detailed description of the differences between Java Comparator Vs Comparable. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template