Implementar compareto java
¿Cómo queremos ordenarlos? ¿Queremos ordenarlos por peso? Si es así, ¿las ordenamos del más ligero al más pesado o del más pesado al más ligero? Cuando las ordenamos, tenemos que comparar repetidamente el peso de dos manzanas hasta que todas las manzanas estén en el orden correcto. ¿Es la manzana 1 más pesada que la manzana 2? ¿Es más pesada que la manzana 3? Tenemos que seguir haciéndolo hasta que la lista esté ordenada. La interfaz de comparables nos ayuda a lograr este objetivo. Comparable no puede ordenar los objetos por sí mismo, pero la interfaz define un método int compareTo(T).
El método compareTo() funciona devolviendo un valor int que es positivo, negativo o cero. Compara el objeto haciendo la llamada al objeto que es el argumento. Un número negativo significa que el objeto que hace la llamada es “menos” que el argumento. Si estuviéramos comparando las manzanas por su tamaño, la llamada anterior devolvería un número negativo, digamos -400, porque la manzana roja es más pequeña que la verde. Si las dos manzanas tuvieran el mismo peso, la llamada devolvería 0. Si la manzana roja fuera más pesada, compareTo() devolvería un número positivo, digamos 68.
Interfaz comparable java
Indagando, descubrí que no es una buena práctica implementar Comparable en tipos mutables porque los objetos pueden cambiar durante o después de la comparación haciendo que el resultado de la misma sea inútil. Tanto AtomicLong como AtomicInteger son mutables. Los diseñadores de la API tuvieron la precaución de no hacer que Number implementara Comparable porque habría limitado la implementación de futuros subtipos. De hecho, AtomicLong y AtomicInteger se añadieron en Java 1.5 mucho después de que se implementara inicialmente java.lang.Number.
Aparte de la mutabilidad, probablemente hay otras consideraciones aquí también. Una implementación de compareTo en Number tendría que promover todos los valores numéricos a BigDecimal porque es capaz de acomodar todos los subtipos de Number. La implicación de esa promoción en términos matemáticos y de rendimiento no está muy clara para mí, pero mi intuición encuentra esa solución torpe.
otra opción podría haber sido declarar que la clase Number implementa Comparable, omitir la implementación de compareTo, e implementarla en algunas clases como Integer mientras que lanzar UnsupportedException en otras como AtomicInteger.
Java genérico comparable
La interfaz Comparable se utiliza para comparar un objeto de la misma clase con una instancia de esa clase, proporciona la ordenación de los datos de los objetos de la clase definida por el usuario. La clase tiene que implementar la interfaz java.lang.Comparable para comparar su instancia, proporciona el método compareTo que toma un parámetro del objeto de esa clase. En este artículo veremos cómo podemos ordenar un array de pares de diferentes tipos de datos en función de los diferentes parámetros de comparación.Usando la interfaz ComparableEjemplo 1Dado un array de Pares formado por dos campos de tipo cadena y entero. hay que ordenar el array en orden Lexicográfico ascendente y si dos cadenas son iguales ordenarlo en función de su valor entero.Ejemplo de E/S:Entrada: { {“abc”, 3}, {“a”, 4}, {“bc”, 5}, {“a”, 2} }
(bc,5)Nota: si dos cadenas son iguales entonces la comparación se hace en base al valor.Ejemplo 2Dado un array de Pares formado por dos cadenas con nombre y apellido. hay que ordenar el array en orden lexicográfico ascendente del nombre y si dos cadenas son iguales ordenarlo en base a su apellido.Ejemplo E/S:Entrada: { {“raj”, “kashup”}, {“rahul”, “singh”}, {“reshmi”, “dubey”}, {“rahul”, “jetli”} }
Java extiende comparable
}El método compareTo requerido por la interfaz devuelve un número entero que nos informa del orden de comparación.Como devolver un número negativo de compareTo() es suficiente si el objeto este es menor que el objeto parámetro, y devolver cero es suficiente cuando las longitudes son iguales, el método compareTo descrito anteriormente también puede ser implementado como sigue.@Override
}Como la clase Member implementa la interfaz Comparable, es posible ordenar la lista utilizando el método sorted. De hecho, los objetos de cualquier clase que implemente la interfaz Comparable pueden ordenarse utilizando el método sorted. Tenga en cuenta, sin embargo, que un flujo no ordena la lista original – sólo se ordenan los elementos en el flujo.Si un programador quiere organizar la lista original, se debe utilizar el método sort de la clase Collections. Esto, por supuesto, supone que los objetos de la lista implementan la interfaz Comparable.Ordenar los miembros del club es sencillo ahora.List<Member> member = new ArrayList<>();
matti (187)Cargando la interfaz…:Cargando la interfaz…Inicia sesión para ver el método quizLoadingLoadingSorting como expresión LambdaSupongamos que tenemos la siguiente clase Persona para usarla.Public class Persona {