The thenComparingDouble(java.util.function.ToDoubleFunction) method of Comparator Interface in Java returns a lexicographic-order comparator with a function that extracts a double sort key. This method is applied after comparing method if you want to apply another comparing for those values which are equal in the comparing method.
Syntax:
default Comparator <T> thenComparingDouble( ToDoubleFunction <T> keyExtractor)
Parameters: This method accepts keyExtractor which is the function used to extract the Double sort key.
Return value: This method returns a lexicographic-order comparator composed of this and then the Double sort key.
Exception: This method throws NullPointerException if the argument is null.
Below programs illustrate thenComparingDouble(java.util.function.ToDoubleFunction) method:
Program 1:
// Java program to demonstrate Comparator // thenComparingDouble(ToDoubleFunction) method import java.util.Arrays; import java.util.Collections; import java.util.Comparator; import java.util.List; public class GFG { public static void main(String[] args) { List<Student> list = getStudentList(); Comparator<Student> comparator = Comparator .comparing(Student::getSchool) .thenComparingDouble(Student::getpercentageMarks); Collections.sort(list, comparator); System.out.println( "After sort" ); list.forEach(s -> System.out.println(s)); } public static List<Student> getStudentList() { Student s1 = new Student( "Ram" , 85.5 , "SJV" ); Student s2 = new Student( "Shyam" , 83.25 , "MSH" ); Student s3 = new Student( "Mohan" , 86.55 , "SJV" ); Student s4 = new Student( "Sohan" , 81.00 , "MSH" ); Student s5 = new Student( "Rabi" , 55.6 , "SJV" ); List<Student> list = Arrays.asList(s1, s2, s3, s4, s5); return list; } } class Student { private String name; private double percentageMarks; private String school; public Student(String name, double percentageMarks, String school) { this .name = name; this .percentageMarks = percentageMarks; this .school = school; } public String getName() { return name; } public void setName(String name) { this .name = name; } public double getpercentageMarks() { return percentageMarks; } public void setpercentageMarks( int percentageMarks) { this .percentageMarks = percentageMarks; } public String getSchool() { return school; } public void setSchool(String school) { this .school = school; } @Override public String toString() { return "Student [name=" + name + ", percentageMarks = " + percentageMarks + ", school=" + school + "]" ; } } |
The output printed on console of IDE is shown below.
Output:
You can see in example first sorting is done on school wise and if the school is same then percentageMarks wise.
Program 2:
// Java program to demonstrate Comparator // thenComparingDouble(ToDoubleFunction) method import java.util.Arrays; import java.util.Comparator; import java.util.List; public class GFG { public static void main(String... args) { List<Integer> list = Arrays.asList( 1 , 2 , 3 , 4 , 5 , 6 ); try { // apply thenComparingDouble Comparator.comparing(list::get) .thenComparingDouble( null ); } catch (Exception e) { System.out.printf( "Exception:" + e); } } } |
The output printed on console is shown below.
Output: