JDK8对Map集合进行排序

  • 根据Map集合的value值进行排序
    public static void main(String[] args) {
        // 创建一个Map
        Map<String, Integer> map = new HashMap<>();
        map.put("小明", 1);
        map.put("小红", 3);
        map.put("张三", 2);
        map.put("李四", 4);
        // 正序配列
        List<Map.Entry<String, Integer>> sortedMapOne = mapValueAsc(map);
        for (Map.Entry<String, Integer> entry : sortedMapOne) {
            System.out.println("Key: " + entry.getKey() + ", Value: " + entry.getValue());
        }
        System.out.println("-----------------------------------------------------");
        // 倒叙排列
        List<Map.Entry<String, Integer>> sortedMapTwo = mapValueDesc(map);
        // 打印排序后的Map
        for (Map.Entry<String, Integer> entry : sortedMapTwo) {
            System.out.println("Key: " + entry.getKey() + ", Value: " + entry.getValue());
        }
    }

    // 根据value值正叙排列
    public static List<Map.Entry<String, Integer>> mapValueAsc(Map<String,Integer> map){
        return map.entrySet().stream().sorted(Map.Entry.comparingByValue()).collect(Collectors.toList());
    }

    // 根据value值倒叙排列
    public static List<Map.Entry<String, Integer>> mapValueDesc(Map<String,Integer> map){
        return map.entrySet().stream().sorted(Map.Entry.<String,Integer>comparingByValue().reversed()).collect(Collectors.toList());
    }
  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
JDK7及以上版本中,可以通过实现Comparator接口来对Map进行排序。Comparator接口是一个用于比较对象的接口,它有一个compare()方法,用于比较两个对象的大小。我们可以通过实现这个接口来定义Map排序规则。 首先,我们需要将Map的entrySet()方法返回的Set集合转换成List集合,然后使用Collections.sort()方法对List集合进行排序。在排序时,我们需要自定义一个Comparator对象来指定排序规则。对于Map而言,我们可以按照key或value进行排序。 下面是一个按照value排序的示例代码: Map<String, Integer> map = new HashMap<String, Integer>(); List<Entry<String, Integer>> list = new ArrayList<Entry<String, Integer>>(map.entrySet()); Collections.sort(list, new Comparator<Entry<String, Integer>>() { public int compare(Entry<String, Integer> o1, Entry<String, Integer> o2) { return o1.getValue().compareTo(o2.getValue()); } }); for (Entry<String, Integer> entry : list) { System.out.println(entry.getKey() + ":" + entry.getValue()); } 在这个示例中,我们首先将Map的entrySet()方法返回的Set集合转换成List集合,然后通过Collections.sort()方法对List集合进行排序。在排序时,我们自定义了一个匿名内部类实现Comparator接口,它将两个Entry对象的value进行比较,并返回比较结果。最后,我们遍历排序后的List集合,并输出每个entry的key和value。 当然,如果要按照key进行排序,我们只需要在Comparator的compare()方法中将o1.getKey()和o2.getKey()进行比较即可。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值