Map排序,按key排序,按value排序,jdk8,lamda。

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博客

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值