Skip to main content

How to sort list of objects in java with examples

We could achieve list of objects sorting in java by using sort() method which is available under Collections class as well as by using Comparable and Comparator interfaces. Comparable and Comparator are two interfaces in java used to sort list of objects. These interfaces are available under java.util package along with Collections class and other classes and interfaces.

Comparable interface contains the method of 

     public int compareTo(Object obj)

Comparator interface contains the method of 

     public int compare(Object obj1, Object obj2)

The compare() and compareTo() methods will return negative integer(-1), or zero(0) or positive integer(1). When the first obj1 is less than obj2 method will return negative integer. When obj1 is equals to obj2 will return zero and when obj1 is grater than obj2 it will return positive integer.

If it's objects are stored in any Collection classes like ArrayList, HashSet in Array and that time we need to use compare() or compareTo() methods to sort.

If you see the logical difference between these two interfaces is Comparator in java compare two objects passing them into compare() method. Comparable interface compare one object with another providing object into compareTo() method.

If any class implements Comparable interface in java then collection of that object either List or an Array can be sorted by using Array.sort() or Collections.sort() then objects will get save based on their natural order defined by compareTo() method.

Now, we will see how to compare List<Employee> objects based on their lName field.

Sorting by using Comparable interface: 
First, we need to create Employee.java class with fname and lname two fields.

Employee.java 
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
package com.javatbrains.compare;

class Employee implements Comparable<Object>{
    
    String fname;
    String lname;
    public Employee(String fname, String lname) {
        super();
        this.fname = fname;
        this.lname = lname;
    }
   
    public String getFname() {
        return fname;
    }
    public String getLname() {
        return lname;
    }

    public int compareTo(Object obj){
     Employee person=(Employee) obj;
        return this.lname.compareTo(person.getLname());
    }
}

Then we have write EmployeeComparable class which will prints the result by executing the main() method.

EmployeeComparable.java 
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
package com.javatbrains.compare;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class EmployeeComparable {
    
    public static void main(String[] args) {
       
        List<Employee> emp = new ArrayList<Employee>();
       
        emp.add(new Employee("Subba","Reddy"));
        emp.add(new Employee("Samba","Siva"));
        emp.add(new Employee("Nalla","Machu"));
       
        Collections.sort(emp);
       
        for (Employee e:emp){
            System.out.println(e.getFname()+" "+e.getLname());
        }
    }
}

Output:
Nalla Machu
Subba Reddy
Samba Siva

Sorting by using Comparator interface:
Now, I am going to create one more Employee.java class with name and age fields,

Employee.java
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
package com.javatbrains.compare;

class Employee{
    
    String firstname;
    Integer age;
    public Employee(String firstname, Integer age) {
        super();
        this.firstname = firstname;
        this.age = age;
    }
   
    public String getFirstname() {
        return firstname;
    }
    public Integer getAge() {
        return age;
    }
}

Then I am going to create TestComparator.java class which was implemented with Comparator interface.

TestComparator.java
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package com.javatbrains.compare;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class TestComparator implements Comparator<Object> {

    public int compare(Object obj1, Object obj2){
        Employee p1=(Employee) obj1;
        Employee p2=(Employee) obj2;
       
        String p1name=p1.getFirstname()+" "+p1.getAge();
        String p2name=p2.getFirstname()+" "+p2.getAge();
       
        return p1name.compareTo(p2name);
    }

    public static void main(String[] args) {
         List <Employee> elist= new ArrayList<Employee>();
       
         elist.add(new Employee("Arvind",25));
         elist.add(new Employee("Arvind",15));
         elist.add(new Employee("Arvind",20));
       
         Collections.sort(elist, new TestComparator());
       
         for(Employee e:elist){
             System.out.println(e.firstname+ " "+e.getAge());
         }
    }
   
}

Output:
Arvind 15
Arvind 20
Arvind 25

Comments

Popular posts from this blog

JNDI configuration for Tomcat 9 with Oracle

In this article, I am going to place the required source code to get data from the table by using the JNDI configuration. Below are the environment details that I have configured currently. Windows - 7 Oracle - 10g Tomcat - 9 JDK - 8 Eclipse Oxygen Ojdbc6 jar required First, we need to create the Dynamic Web Project. If you don't know how to do <Click Here>. I have faced a lot of issues before getting the output like 405, No driver class to load, etc. I am using JSP & Servlets in the current explanation. Before started writing the application logic, we need to do the below configuration in the installed tomcat directory. Place OJDBC6.jar in the Tomcat LIB directory. Add this Resource under <GlobalNamingResources> in Server.xml file which is present under the conf directory in Tomcat. < Resource name = "jdbc/myoracle" global= "jdbc/myoracle" auth = "Container" type= "javax.sql.DataSource" driverClass...

Prime, Fibonacci and Factorial number with example in java

Prime number, Fibonacci series and Factorial number programs are most commonly asked questions in interview. Read this article to know what is and how to write programs for prime number, fibonacci series and factorial number. Prime Number: prime number is natural number greater than 1 that has no positive divisor other than 1 and itself. A natural number greater than 1 is not a prime number, is called Composite number . For example, 7 is a prime number. Because it can divide with 1 and 7 only. Where as 8 is composite number. Since it has the divisor 2 and 4 in addition to the 1 and 8. The below example represents the finding the passing number is prime number or not. If the passing number is prime number it will print true otherwise it will print false. package com . javatbrains . practice ; public class PrimeNumber { public boolean isPrimeNumber ( int number ) { if ( number <= 1 ) return false ; // There's only one ...

JVM, JRE and JDK in Java

JVM, JRE and JDK are the most basic common concepts to know in java. These are the basic features to understand how Java architecture works? JVM stands for Java Virtual Machine, which doesn't have any physical directories created in java installation. JRE stands for Java Runtime Environment, which creates the directory under Java installation path and also present in JDK. JDK stands for Java Development Kit, which creates the directory in Java installation path and also it has it's own JRE. Since we have already learn that Java is platform independent means if we have implemented any of the java class in one environment, it will be executed in any other environment and provides the same output. But, JVM, JRE and JDK all are platform dependent . So that, for windows, linux, unix, mac, solaris..etc has it's own JVM, JRE and JDK. One will be not compatible with other environments. While installing the Java, we might come to know a bit about JRE and JDK. But, JVM is the other...