欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-07-22 09:30:47
引言 最近小编自己一个人在负责一个项目的后台开发,其中有一部分是统计相关的功能,所以需要一些排序或者分组的操作,之前这种操作小编觉得还是比较麻烦的,虽热有一些现成的工具类...

引言

最近小编自己一个人在负责一个项目的后台开发,其中有一部分是统计相关的功能,所以需要一些排序或者分组的操作,之前这种操作小编觉得还是比较麻烦的,虽热有一些现成的工具类,但是工具类的写法也是比较复杂的,但是如果使用java8 stream流的话就比较简单了,并且代码量会大大的减少,下面总结几个对map的操作。

1、map 根据value排序

map<string,bigdecimal> map =new hashmap<>();
map.put("one", 0.08);
map.put("two", 0.1);
map.put("three", 0.2);
map.put("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<>();
 
    map.entryset().stream()
        .sorted(map.entry.<k, v>comparingbyvalue()
            .reversed()).foreachordered(e -> result.put(e.getkey(), e.getvalue()));
    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<>();
 
    map.entryset().stream()
        .sorted(map.entry.<k, v>comparingbykey()
            .reversed()).foreachordered(e -> result.put(e.getkey(), e.getvalue()));
    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<>();
 
    map.entryset().stream()
        .sorted(map.entry.<k, v>comparingbyvalue()
            ).foreachordered(e -> result.put(e.getkey(), e.getvalue()));
    return result;
  }

小结

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