stream流对map的key和value进行排序(支持字符串)

1.方法介绍

Map.Entry.comparingByValue():根据value排序
Map.Entry.comparingByKey():根据key排序

2.具体代码

package com.zyp.test;


import com.google.common.collect.Maps;

import java.util.LinkedHashMap;
import java.util.Map;
import java.util.stream.Collectors;

/**
 * @author syl
 * @description map的stream流使用
 * @since 2021/4/19
 */
public class StreamMap {
    public static void main(String[] args) {
        Map<String,Integer> map= Maps.newHashMap();
        map.put("d",4);
        map.put("e",5);
        map.put("f",1);
        map.put("b",2);
        map.put("c",3);
        //根据key排序
 		//(oldValue,newValue)->(newValue)指定value重复之后按照那个值输出       
 		map.entrySet().stream().sorted(Map.Entry.comparingByKey(String::compareTo)).
                collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue, (oldValue,newValue)->oldValue, LinkedHashMap::new)).
                forEach((K,V)-> System.out.println(K+":"+V));
        //根据value排序
        System.out.println("------------------------------------");
        map.entrySet().stream().sorted(Map.Entry.comparingByValue(Integer::compareTo)).
                collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue, (oldValue,newValue)->oldValue, LinkedHashMap::new)).
                forEach((K,V)-> System.out.println(K+":"+V));
    }
}
这段Java代码是在使用`LinkedHashMap`并对其中的条目(`Map.Entry`)根据值进行排序后,将结果转换成一个新的`Map`。`map.entrySet().stream().sorted(Map.Entry.comparingByValue()).collect(Collectors.toMap());`这一部分的意思是: 1. 首先,通过`.entrySet()`获取到当前`LinkedHashMap`的所有映射项(key-value对)作为一个(Stream)。 2. 然后,`.sorted(Map.Entry.comparingByValue())`使用`Comparator.comparingByValue()`来指定按照值(value Property)进行自然顺序的升序或降序排序。默认是升序排序,如果要降序排序,需要添加 `.reversed()`。 3. 最后,`.collect(Collectors.toMap())`将排序后的转换回一个新的`Map`,这里的`Collectors.toMap()`通常需要传入两个函数作为参数:第一个是键生成器(keyMapper),第二个是值合并器(valueMapper)。对于`LinkedHashMap`而言,如果不提供这两个函数,它会尝试创建一个新的`LinkedHashMap`,并且默认键是唯一的,如果有重复的值,后面的映射项会覆盖前面的。 如果想保持排序后的新`Map`仍然是`LinkedHashMap`,并且键是唯一的,你可以这么补充: ```java Map<Comparable<? super K>, V> resultMap = list.stream() .sorted(Comparator.comparing(MyClass::getValueProperty)) // 或者加上.reversed()进行降序排序 .collect(Collectors.toMap( Function.identity(), // 使用默认的 keyMapper,即元素本身作为新Map的键 Function.identity(), // 使用默认的 valueMapper,即元素的值作为新Map的值 (oldValue, newValue) -> oldValue)); // 如果希望新值覆盖旧值,可以省略这行 ``` 这样,`resultMap`就会是一个新的、按照值排序的`LinkedHashMap`。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值