De acuerdo con llave
Se requiere el método compareTo () y clase Comparador TreeMap.
import java.util.Comparator;
import java.util.Map;
import java.util.TreeMap;
public class Test_sort{
public static void main(String[] args) {
Map<String,String>map = new TreeMap<>(new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
//降序
//return o2.compareTo(o1);
//升序
return o1.compareTo(o2);
}
});
map.put("2","Language");
map.put("1","Java Language");
map.put("3","C Language");
System.out.println(map);
}
}
Entre ellos, el mapa definición de expresiones lambda se puede escribir como
Map<String,String>map = new TreeMap<>((o1, o2) -> {
//降序
//return o2.compareTo(o1);
//升序
return o1.compareTo(o2);
});
De acuerdo con el valor
Requiere la Collections.sort () y Lambda Expresiones
Las expresiones lambda. 1
Lambda Expresión 2
import java.util.*;
public class Test_sort {
public static void main(String[] args) {
Map<String, String> map = new HashMap<>();
map.put("A", "33");
map.put("B", "31");
map.put("C", "35");
List<Map.Entry<String, String>> list = new ArrayList<>(map.entrySet());
Collections.sort(list, new Comparator<Map.Entry<String, String>>() {
@Override
public int compare(Map.Entry<String, String> o1, Map.Entry<String, String> o2) {
int compare = (o1.getValue()).compareTo(o2.getValue());
//升序
return compare;
//降序
//return -compare;
}
});
for (Map.Entry<String, String> maps : list) {
System.out.println(maps.getKey() + " " + maps.getValue());
}
}
}
Tales operaciones no son en realidad una especie mapa en sí, cambiar el orden de la lista.