Comparator Interface in Java with Examples
Last Updated :
05 Apr, 2023
A comparator interface is used to order the objects of user-defined classes. A comparator object is capable of comparing two objects of the same class. Following function compare obj1 with obj2.
Syntax:
public int compare(Object obj1, Object obj2):
Suppose we have an Array/ArrayList of our own class type, containing fields like roll no, name, address, DOB, etc, and we need to sort the array based on Roll no or name?
Method 1: One obvious approach is to write our own sort() function using one of the standard algorithms. This solution requires rewriting the whole sorting code for different criteria like Roll No. and Name.
Method 2: Using comparator interface- Comparator interface is used to order the objects of a user-defined class. This interface is present in java.util package and contains 2 methods compare(Object obj1, Object obj2) and equals(Object element). Using a comparator, we can sort the elements based on data members. For instance, it may be on roll no, name, age, or anything else.
Method of Collections class for sorting List elements is used to sort the elements of List by the given comparator.
public void sort(List list, ComparatorClass c)
To sort a given List, ComparatorClass must implement a Comparator interface.
How do the sort() method of Collections class work?
Internally the Sort method does call Compare method of the classes it is sorting. To compare two elements, it asks “Which is greater?” Compare method returns -1, 0, or 1 to say if it is less than, equal, or greater to the other. It uses this result to then determine if they should be swapped for their sort.
Example
Java
import java.io.*;
import java.lang.*;
import java.util.*;
class Student {
int rollno;
String name, address;
public Student( int rollno, String name, String address)
{
this .rollno = rollno;
this .name = name;
this .address = address;
}
public String toString()
{
return this .rollno + " " + this .name + " "
+ this .address;
}
}
class Sortbyroll implements Comparator<Student> {
public int compare(Student a, Student b)
{
return a.rollno - b.rollno;
}
}
class Sortbyname implements Comparator<Student> {
public int compare(Student a, Student b)
{
return a.name.compareTo(b.name);
}
}
class GFG {
public static void main(String[] args)
{
ArrayList<Student> ar = new ArrayList<Student>();
ar.add( new Student( 111 , "Mayank" , "london" ));
ar.add( new Student( 131 , "Anshul" , "nyc" ));
ar.add( new Student( 121 , "Solanki" , "jaipur" ));
ar.add( new Student( 101 , "Aggarwal" , "Hongkong" ));
System.out.println( "Unsorted" );
for ( int i = 0 ; i < ar.size(); i++)
System.out.println(ar.get(i));
Collections.sort(ar, new Sortbyroll());
System.out.println( "\nSorted by rollno" );
for ( int i = 0 ; i < ar.size(); i++)
System.out.println(ar.get(i));
Collections.sort(ar, new Sortbyname());
System.out.println( "\nSorted by name" );
for ( int i = 0 ; i < ar.size(); i++)
System.out.println(ar.get(i));
}
}
|
Output
Unsorted
111 Mayank london
131 Anshul nyc
121 Solanki jaipur
101 Aggarwal Hongkong
Sorted by rollno
101 Aggarwal Hongkong
111 Mayank london
121 Solanki jaipur
131 Anshul nyc
Sorted by name
101 Aggarwal Hongkong
131 Anshul nyc
111 Mayank london
121 Solanki jaipur
By changing the return value inside the compare method, you can sort in any order that you wish to, for example: For descending order just change the positions of ‘a’ and ‘b’ in the above compare method.
Sort collection by more than one field
In the previous example, we have discussed how to sort the list of objects on the basis of a single field using the Comparable and Comparator interface But, what if we have a requirement to sort ArrayList objects in accordance with more than one field like firstly, sort according to the student name and secondly, sort according to student age.
Example
Java
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;
import java.util.List;
class Student {
String Name;
int Age;
public Student(String Name, Integer Age)
{
this .Name = Name;
this .Age = Age;
}
public String getName() { return Name; }
public void setName(String Name) { this .Name = Name; }
public Integer getAge() { return Age; }
public void setAge(Integer Age) { this .Age = Age; }
@Override public String toString()
{
return "Customer{"
+ "Name=" + Name + ", Age=" + Age + '}' ;
}
}
class CustomerSortingComparator
implements Comparator<Student> {
@Override
public int compare(Student customer1, Student customer2)
{
int NameCompare = customer1.getName().compareTo(
customer2.getName());
int AgeCompare = customer1.getAge().compareTo(
customer2.getAge());
return (NameCompare == 0 ) ? AgeCompare
: NameCompare;
}
}
class GFG {
public static void main(String[] args)
{
List<Student> al = new ArrayList<>();
Student obj1 = new Student( "Ajay" , 27 );
Student obj2 = new Student( "Sneha" , 23 );
Student obj3 = new Student( "Simran" , 37 );
Student obj4 = new Student( "Ajay" , 22 );
Student obj5 = new Student( "Ajay" , 29 );
Student obj6 = new Student( "Sneha" , 22 );
al.add(obj1);
al.add(obj2);
al.add(obj3);
al.add(obj4);
al.add(obj5);
al.add(obj6);
Iterator<Student> custIterator = al.iterator();
System.out.println( "Before Sorting:\n" );
while (custIterator.hasNext()) {
System.out.println(custIterator.next());
}
Collections.sort(al,
new CustomerSortingComparator());
System.out.println( "\n\nAfter Sorting:\n" );
for (Student customer : al) {
System.out.println(customer);
}
}
}
|
Output
Before Sorting:
Customer{Name=Ajay, Age=27}
Customer{Name=Sneha, Age=23}
Customer{Name=Simran, Age=37}
Customer{Name=Ajay, Age=22}
Customer{Name=Ajay, Age=29}
Customer{Name=Sneha, Age=22}
After Sorting:
Customer{Name=Ajay, Age=22}
Customer{Name=Ajay, Age=27}
Customer{Name=Ajay, Age=29}
Customer{Name=Simran, Age=37}
Customer{Name=Sneha, Age=22}
Customer{Name=Sneha, Age=23}
Like Article
Suggest improvement
Share your thoughts in the comments
Please Login to comment...