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

网友投稿 803 2022-12-28


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

引言

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

1、map 根据value排序

Map 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 > Map sortByValue(Map map) {

Map result = new LinkedHashMap<>();

map.entrySet().stream()

.sorted(Map.Entry.comparingByValue()

.reversed()).forEachOrdered(e -> result.put(e.getKey(), e.getValue()));

return resuhttp://lt;

}

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

public , V > Map sortByKey(Map map) {

Map result = new LinkedHashMap<>();

map.entrySet().stream()

.sorted(Map.Entry.comparingByKey()

.reversed()).forEachOrdered(e -> result.put(e.getKey(), e.getValue()));

return result;

}

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

public > Map sortByValue(Map map) {

Map result = new LinkedHashMap<>();

map.entrySet().stream()

.sorted(Map.Entry.comparingByValue()

).forEachOrdered(e -> result.put(e.getKey(), e.getValue()));

return result;

}

小结


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:系统接口设计图片(系统接口设计图片大全)
下一篇:完全开源接口测试工具(接口测试的工具)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~