Mefisto_Fell:
Estudio la API de corriente, tengo esta tarea. Necesito clasificar la colección de lista en el orden de su longitud, si las longitudes de varias líneas son los mismos, a continuación, ordenar por orden alfabético.
Mi código:
List<String> phones = new ArrayList<String>();
Collections.addAll(phones, "iPhone X", "Nokia 9", "Huawei Nexus 6P",
"Samsung Galaxy S8", "LG G6", "Xiaomi MI6", "Sony Xperia Z5",
"ASUS Zenfone 3", "Meizu Pro 6", "Heizu Pro 6",
"Pixel 2");
phones.stream().sorted(Comparator.comparingInt(String::length).reversed()).forEach(System.out::println);
Tengo esta salida:
Samsung Galaxy S8
Huawei Nexus 6P
Sony Xperia Z5
ASUS Zenfone 3
Meizu Pro 6
Heizu Pro 6
Xiaomi MI6
iPhone X
Nokia 9
Pixel 2
LG G6
Como se puede ver las líneas
Sony Xperia Z5
ASUS Zenfone 3
Y líneas:
Meizu Pro 6
Heizu Pro 6
Pero mi resultado tiene que ser:
Samsung Galaxy S8
Huawei Nexus 6P
ASUS Zenfone 3
Sony Xperia Z5
Heizu Pro 6
Meizu Pro 6
Xiaomi MI6
iPhone X
Nokia 9
Pixel 2
LG G6
¿Cómo puedo mejorar mi código de modo que si las longitudes son iguales, entonces la clasificación es alfabético?
¿Cómo podemos hacer resultados se acumulan en la lista>? Cuando List <Pair <String, Long>
por ejemplo:
String a = Abcd;
list.add(new Pair(a, a.length));
Charles Dowbecki:
Añadir thenComparing()
a su cadena de comparador para crear un orden secundario. Se aplicará cuando ordenación principal no es suficiente:
phones.stream()
.sorted(Comparator.comparingInt(String::length).reversed()
.thenComparing(Function.identity()))
.forEach(System.out::println);