¿Cómo usar Collections.sort () en Java? (Situación específica)

Obtuve una Recipe objeto que implementa Comparable :

 public int compareTo(Recipe otherRecipe) { return this.inputRecipeName.compareTo(otherRecipe.inputRecipeName); } 

Lo hice así que puedo ordenar la List alfabéticamente en el siguiente método:

 public static Collection getRecipes(){ List recipes = new ArrayList(RECIPE_MAP.values()); Collections.sort(recipes); return recipes; } 

Pero ahora, en un método diferente, vamos a llamarlo getRecipesSort() , quiero ordenar la misma lista pero numéricamente, comparando una variable que contiene su ID. Para empeorar las cosas, el campo ID es del tipo String .

Use este método Collections.sort (Lista, Comparador) . Implemente un Comparador y páselo a Collections.sort().

 class RecipeCompare implements Comparator { @Override public int compare(Recipe o1, Recipe o2) { // write comparison logic here like below , it's just a sample return o1.getID().compareTo(o2.getID()); } } 

Luego use el Comparator como

 Collections.sort(recipes,new RecipeCompare()); 

La respuesta dada por NINCOMPOOP se puede simplificar usando Lambda Expressions:

Collections.sort(recipes, (Recipe r1, Recipe r2) ->
r1.getID().compareTo(r2.getID()));

También se introdujo después de Java 8 los métodos de construcción del comparador en la interfaz del Comparador . Usando estos, uno puede reducir aún más esto a 1 :

 recipes.sort(comparingInt(Recipe::getId)); 

1 Bloch, J. Effective Java ( edición). 2018. Artículo 42, p. 194.

Cree un comparador que acepte el modo de comparación en su constructor y pase diferentes modos para diferentes escenarios según su requerimiento

 public class RecipeComparator implements Comparator { public static final int COMPARE_BY_ID = 0; public static final int COMPARE_BY_NAME = 1; private int compare_mode = COMPARE_BY_NAME; public RecipeComparator() { } public RecipeComparator(int compare_mode) { this.compare_mode = compare_mode; } @Override public int compare(Recipe o1, Recipe o2) { switch (compare_mode) { case COMPARE_BY_ID: return o1.getId().compareTo(o2.getId()); default: return o1.getInputRecipeName().compareTo(o2.getInputRecipeName()); } } 

}

En realidad, para los números que necesita para manejarlos por separado verifique a continuación

 public static void main(String[] args) { String string1 = "1"; String string2 = "2"; String string11 = "11"; System.out.println(string1.compareTo(string2)); System.out.println(string2.compareTo(string11));// expected -1 returns 1 // to compare numbers you actually need to do something like this int number2 = Integer.valueOf(string1); int number11 = Integer.valueOf(string11); int compareTo = number2 > number11 ? 1 : (number2 < number11 ? -1 : 0) ; System.out.println(compareTo);// prints -1 } 

Use el método que acepta un Comparator cuando desea ordenar algo que no sea el orden natural.

Collections.sort (Lista, Comparador)

Ordene el hashmap desordenado en orden ascendente.

 // Sorting the list based on values Collections.sort(list, new Comparator>() { public int compare(Entry o1, Entry o2) { return o2.getValue().compareTo(o1.getValue()); } }); // Maintaining insertion order with the help of LinkedList Map sortedMap = new LinkedHashMap(); for (Entry entry : list) { sortedMap.put(entry.getKey(), entry.getValue()); }