El método compareDouble ( java.util.function.ToDoubleFunction ) de Comparator Interface en Java acepta una función como parámetro que extrae una clave de ordenación doble de un tipo T y devuelve un comparador que compara por esa clave de ordenación. El comparador devuelto es serializable si la función especificada también es serializable.
Sintaxis:
static <T> Comparator<T> comparingDouble( ToDoubleFunction <T> keyExtractor)
Parámetros: este método acepta un solo parámetro keyExtractor que es la función utilizada para extraer la clave de ordenación doble.
Valor de retorno: este método devuelve un comparador que compara por una clave extraída
Excepción: este método lanza NullPointerException si el argumento es nulo.
Los siguientes programas ilustran el método compareDouble(java.util.function.ToDoubleFunction):
Programa 1:
// Java program to demonstrate Comparator // comparingDouble(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) { // create some user objects User u1 = new User("Aaman", 3500.56); User u2 = new User("Joyita", 4222.99); User u3 = new User("Suvam", 2832.34); User u4 = new User("mahafuj", 2522.76); // before sort List<User> list = Arrays.asList(u2, u1, u4, u3); System.out.println("Before Sort:"); list.forEach(user -> System.out.println(user)); Collections.sort(list, Comparator.comparingDouble(User::getSalary)); System.out.println("\nAfterSort:"); list.forEach(user -> System.out.println(user)); } } class User implements Comparable<User> { public String name; public double salary; public User(String name, double d) { this.name = name; this.salary = d; } public int compareTo(User u1) { return name.compareTo(u1.name); } public String getName() { return name; } public void setName(String name) { this.name = name; } public double getSalary() { return salary; } public void setSalary(double salary) { this.salary = salary; } @Override public String toString() { return "User [name=" + name + ", salary=" + salary + "]"; } }
La salida impresa en la consola de IDE se muestra a continuación.
Producción:
Programa 2:
// Java program to demonstrate Comparator // comparingDouble(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) { // before sort List<Order> list = Arrays.asList( new Order("A382y482y48", 32684.82), new Order("Vvekhfbkje2", 28348.47), new Order("efkhfbekjfbe", 47674.49), new Order("bhdhdfaddvad", 78449.43), new Order("abkasbcjabjc", 10104.43)); System.out.println("Before Sort:"); list.forEach(order -> System.out.println(order)); Collections.sort(list, Comparator.comparingDouble(Order::getValue)); System.out.println("\nAfter Sort:"); list.forEach(order -> System.out.println(order)); } } class Order implements Comparable<Order> { public String orderNo; public double value; public int compareTo(Order o1) { return orderNo.compareTo(o1.orderNo); } public Order(String orderNo, double value) { super(); this.orderNo = orderNo; this.value = value; } @Override public String toString() { return "Order [orderNo=" + orderNo + ", value=" + value + "]"; } public String getOrderNo() { return orderNo; } public void setOrderNo(String orderNo) { this.orderNo = orderNo; } public double getValue() { return value; } public void setValue(double value) { this.value = value; } }
El resultado impreso en la consola se muestra a continuación.
Producción:
Publicación traducida automáticamente
Artículo escrito por AmanSingh2210 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA