java8 stream 操作map根据key或者value排序

时间:2024-11-09 15:23:23

引言

1、map 根据value排序

Map<String,BigDecimal> map =new HashMap<>();
("one", 0.08);
("two", 0.1);
("three", 0.2);
("four", 0.91);

上面是项目中的一个中间结果,我们需要对这个map根据value值倒序排序,下面给出工具类:

    public <K, V extends Comparable<? super V>> Map<K, V> sortByValue(Map<K, V> map) {
        Map<K, V> result = new LinkedHashMap<>();

        ().stream()
                .sorted(.<K, V>comparingByValue()
                        .reversed()).forEachOrdered(e -> ((), ()));
        return result;
    }

当然如果我们想根据map的key进行排序,需要对上面的工具类进行小小的修改,代码如下:

 public <K extends Comparable<? super K>, V > Map<K, V> sortByKey(Map<K, V> map) {
        Map<K, V> result = new LinkedHashMap<>();

        ().stream()
                .sorted(.<K, V>comparingByKey()
                        .reversed()).forEachOrdered(e -> ((), ()));
        return result;
    }

我们可以看到,如果我们需要根据key排序,就需要让key 继承 Comparable ,也就说我们需要对待排序的字段继承 Comparable接口。另一个问题就是,上面的这种写法排序效果是 降序排序,如果我们需要升序排序的话,只需要将上面的.reversed()关键字限制去掉即可。

  public <K, V extends Comparable<? super V>> Map<K, V> sortByValue(Map<K, V> map) {
        Map<K, V> result = new LinkedHashMap<>();

        ().stream()
                .sorted(.<K, V>comparingByValue()
                        ).forEachOrdered(e -> ((), ()));
        return result;
    }

小结

  java8提供了一些非常简便的写法,我们还是需需要多用一些,希望能对读者有些帮助