1、按照key排序:
利用TreeMap,TreeMap中的数据是根据key值对象中的对比方法(comparaTo)的运行结果进行存储,所以可以直接利用TreeMap将Map中的key进行排序。
2、按照value排序:
将待排序Map中的所有元素置于一个list列表中,然后使用Collections的一个静态方法 sort(List<T> list, Comparator<? super T> c)
来排序list,用比较器定义比较规则。
上代码:
Map<String, String> map= new TreeMap<String, String>();
map.put("1", "5.369");
map.put("5", "4.369");
map.put("3", "8.369");
map.put("2", "8.366");
System.out.println(map);
List<Map.Entry<String, String>> list = new ArrayList<Map.Entry<String, String>>(map.entrySet());
// 通过比较器实现比较排序
Collections.sort(list, new Comparator<Map.Entry<String, String>>() {
@Override
public int compare(Map.Entry<String, String> mapping1, Map.Entry<String, String> mapping2) {
return mapping1.getValue().compareTo(mapping2.getValue());// value降序,需要升序则调换mapping1和mapping2位置
}
});
for (String key : map.keySet()) {
System.out.println(key + " :" + map.get(key));
}
结果:
jdk8+可以使用lamda,更简洁
Map<String, String> treeMap = new TreeMap<String, String>();
treeMap.put("1", "5.369");
treeMap.put("5", "4.369");
treeMap.put("3", "8.369");
treeMap.put("2", "8.366");
System.out.println(treeMap);
List<Map.Entry<Long, Double>> list = new ArrayList<>(treeMap.entrySet());
// 通过比较器实现比较排序
Collections.sort(list, Comparator.comparing(Map.Entry::getValue));// value升序
Collections.sort(list, (mapping1, mapping2) -> mapping2.getValue().compareTo(mapping1.getValue()));// value降序
遍历map获取key和value的方法可查看:Java遍历Map对象的四种方式_安静读书的博客-CSDN博客