Core JAVA

Java Comparable and comparator

In this tutorial, it shows the use of java.lang.Comparable and java.util.Comparator to sort a Java object based on its property value. Java provides some inbuilt methods to sort primitive types array or Wrapper classes array or list. Here we will first learn how we can sort an array/list of primitive types and wrapper classes and then we will use java.lang.Comparable and java.util.Comparator interfaces to sort array/list of custom classes.

Difference between comparable and comparator in java

In Java, the element in collections can be sorted by using TreeSet or TreeMap. To sort the data elements a class needs to implement Comparator or Comparable interface. That’s why all Wrapper classes like Integer, Double and String class implements the Comparable interface.

A class implementing Comparable interface need to override compareTo(Object obj) method and put the logic for sorting.

The method returns an int value: -1,0,1

  • It will return -1: If this object is lesser than the passed object
  • It will return 0: If this object is same the passed object
  • It will return 1: If this object is greater than the passed object

Consider a class Person.

class Person {
public String name;
public String lastName;

public Person(String name, String lastName){
 this.name=name;
 this.lastName=lastName;
}
public String getName(){
return name;
}
public String getLastName(){
return lastName;
}

public static void main(String arg[]){
  List myList = new ArrayList();
  myList.add(new Person("Robert","USA"));
  myList.add(new Person("Andy","UK"));
  myList.add(new Person("Harish","India"));
  for(Person person : myList){
    System.out.println("My name is "+person.getName());
  }
}

}

Output is :
My name is Robert
My name is Andy
My name is Harish

But now I want that the objects to be sorted on name basis should be retrieved in sorted order. Consider a class Person.

class Person implements Comparable{
public String name;
public String lastName;

public Person(String name, String lastName){
  this.name=name;
  this.lastName=lastName;
}
public String getName(){
  return name;
}
public String getLastName(){
  return lastName;
}

public int compareTo(Person p){
  return this.name.compareTo(p.getName);
}
public static void main(String arg[]){
  List myList = new ArrayList();
  myList.add(new Person("Robert","USA"));
  myList.add(new Person("Andy","UK"));
  myList.add(new Person("Harish","India"));
  Collections.sort(myList);
  for(Person person : myList){
  System.out.println("My name is "+person.getName());
  }
}
}

Output is :
My name is Andy
My name is Harish
My name is Robert

A couple of things which needs to be taken into consideration:

  • Collections.sort() will sort only the collection having objects which implements either one of the comparing interfaces.
  • Collections.sort() will sort the same list.

Comparator interface

It is used when extra logic is required to sort the objects. One need to override compare(Object obj1, Object obj2) method. For example, you want the list of Person object to be sorted on the basis of complete name i.e “name lastName” but also, on the other hand, doesn’t want to change the Person class-default sorting implementation or Person class is a jar so so no code modification in it can be done. First, create a Custom Comparator.

public class MyCustomComparator implements Comparator{
  public int compare(Object obj1, Object obj2){
    Person p1 =(Person) obj1;
    Person p2 =(Person) ob2;
    String p1Name = p1.getName()+ " " +p1.getLastName();
    String p2Name = p2.getName()+ " " +p2.getLastName();
    return p1Name.toCompareTo(p2Name);
  }
}
// Changes made in main method of Person class.
public static void main(String arg[]){
  List myList = new ArrayList();
  myList.add(new Person("Robert","USA"));
  myList.add(new Person("Robert","UK"));
  myList.add(new Person("Robert","India"));
  Collections.sort(myList new MyCustomComparator());
  for(Person person : myList){
  System.out.println("My name is "+person.getName() + " " + person.getLastName());
  }
}

OutPut:
My name is Robert India
My name is Robert UK
My name is Robert USA

A couple of things which needs to be taken into consideration:

1) For Comparator interface, you need to override method compare(obj)
2) In collections.sort() the instance of Comparator need to be passed. In this example, the list is sorted according to the custom Comparator created.

Refrences-
http://java-questions.com/

 

Previous
Next
Dinesh Rajput

Dinesh Rajput is the chief editor of a website Dineshonjava, a technical blog dedicated to the Spring and Java technologies. It has a series of articles related to Java technologies. Dinesh has been a Spring enthusiast since 2008 and is a Pivotal Certified Spring Professional, an author of a book Spring 5 Design Pattern, and a blogger. He has more than 10 years of experience with different aspects of Spring and Java design and development. His core expertise lies in the latest version of Spring Framework, Spring Boot, Spring Security, creating REST APIs, Microservice Architecture, Reactive Pattern, Spring AOP, Design Patterns, Struts, Hibernate, Web Services, Spring Batch, Cassandra, MongoDB, and Web Application Design and Architecture. He is currently working as a technology manager at a leading product and web development company. He worked as a developer and tech lead at the Bennett, Coleman & Co. Ltd and was the first developer in his previous company, Paytm. Dinesh is passionate about the latest Java technologies and loves to write technical blogs related to it. He is a very active member of the Java and Spring community on different forums. When it comes to the Spring Framework and Java, Dinesh tops the list!

Share
Published by
Dinesh Rajput

Recent Posts

Strategy Design Patterns using Lambda

Strategy Design Patterns We can easily create a strategy design pattern using lambda. To implement…

2 years ago

Decorator Pattern using Lambda

Decorator Pattern A decorator pattern allows a user to add new functionality to an existing…

2 years ago

Delegating pattern using lambda

Delegating pattern In software engineering, the delegation pattern is an object-oriented design pattern that allows…

2 years ago

Spring Vs Django- Know The Difference Between The Two

Technology has emerged a lot in the last decade, and now we have artificial intelligence;…

3 years ago

TOP 20 MongoDB INTERVIEW QUESTIONS 2022

Managing a database is becoming increasingly complex now due to the vast amount of data…

3 years ago

Scheduler @Scheduled Annotation Spring Boot

Overview In this article, we will explore Spring Scheduler how we could use it by…

3 years ago