对Java的Map的Value字段进行排序

本文介绍如何在Java中对Map的Value字段进行排序,提供三种不同版本的代码实现,包括Java 7和Java 8的解决方案。通过将Map转换为List,使用Collections.sort或Stream API进行排序,再转换回LinkedHashMap,保持元素的插入顺序。

  构造TreeMap可以指定Comparator,但是不能对value字段进行排序。如果有需求对Value字段排序,例如map存放的是单词,单词出现次数,怎么按单词次数排序呢?

  可以先将map中的key-value放入list,然后用Collections.sort对list排序,再将排序后的list放入LinkedHashMap,最后返回LinkedHashMap就可以了。LinkedHashMap可是个宝贝,可以通过构造方法制定是按放入的顺序,还是get顺序 排序。LinkedHashMap,稍微修改,可以很容易的实现LRU算法(最近最少使用)。具体的TreeMap 红黑树实现和LinkedHashMap实现还仔细看。

  废话不多说,上代码:

public class MapUtil {
    public static <K, V extends Comparable<? super V>> Map<K, V> sortByValue(Map<K, V> map) {
        List<Map.Entry<K, V>> list = new LinkedList<Map.Entry<K, V>>(map.entrySet());
        Collections.sort(list, new Comparator<Map.Entry<K, V>>() {
            public int compare(Map.Entry<K, V> o1, Map.Entry<K, V> o2) {
                return (o1.getValue()).compareTo(o2.getValue());
            }
        });

        Map<K, V> result = new LinkedHashMap<K, V>();
        for (Map.Entry<K, V> entry : list) {
            result.put(entry.getKey(), entry.getValue());
        }
        return result;
    }
}

 Java 7 Version

public static <K, V extends Comparable<? super V>> Map<K, V> sortByValue(Map<K, V> map) {
        List<Map.Entry<K, V>> list = new LinkedList<>(map.entrySet());
        Collections.sort(list, new Comparator<Map.Entry<K, V>>() {
            @Override
            public int compare(Map.Entry<K, V> o1, Map.Entry<K, V> o2) {
                return (o1.getValue()).compareTo(o2.getValue());
            }
        });

        Map<K, V> result = new LinkedHashMap<>();
        for (Map.Entry<K, V> entry : list) {
            result.put(entry.getKey(), entry.getValue());
        }
        return result;
    }

 java 8 version

public static <K, V extends Comparable<? super V>> Map<K, V> sortByValue(Map<K, V> map) {
        Map<K, V> result = new LinkedHashMap<>();
        Stream<Entry<K, V>> st = map.entrySet().stream();

        st.sorted(Comparator.comparing(e -> e.getValue())).forEach(e -> result.put(e.getKey(), e.getValue()));

        return result;
    }

java 8 版本的代码好短啊 ~

以后做个工具包,像这样的排序直接用工具包使用就可以了。

参考资料:http://stackoverflow.com/questions/109383/how-to-sort-a-mapkey-value-on-the-values-in-java  

转自:对Java的Map的Value字段进行排序

### Java MapValue 排序 对于Java中`Map`按照其值(`value`)进行排序的需求,可以采用多种方式实现。一种常见的方式是利用Stream API结合Lambda表达式完成这一操作[^4]。 下面是一个具体的例子,该示例展示了如何创建一个`Map<String, BigDecimal>`类型的对象并对其进行初始化;之后通过调用`entrySet().stream()`方法获得键值对的流形式,并借助于`sorted(comparingByValue())`来进行升序或降序排列(此处使用`.reversed()`表示降序)。最终,经由`collect(Collectors.toMap(...))`将已排序的结果重新组装成一个新的映射表,在此过程中为了维持原有的键而选择了`Entry::getKey`作为第一个参数传递给`toMap`构造器,同样地以`Entry::getValue`确保原始值得以保存。考虑到可能存在的重复键情况,默认情况下采取保留旧有的值策略`(oldValue, newValue) -> oldValue`,不过在此场景下因为键唯一性假设故实际上并不会触发合并逻辑。特别指出的是,这里选用`LinkedHashMap::new`来构建返回的新容器,以此保障迭代顺序能够反映之前定义好的排序状态——即依据值大小呈递减趋势展示出来: ```java import java.math.BigDecimal; import java.util.*; import java.util.stream.Collectors; public class SortMapExample { public static void main(String[] args) { // 创建并填充测试数据到 mapMap<String, BigDecimal> hMap = new HashMap<>(); hMap.put("apple", new BigDecimal(1)); hMap.put("banana", new BigDecimal(3)); hMap.put("orange", new BigDecimal(2)); // 对 map 进行按 value 值降序排序 Map<String, BigDecimal> sortedMap = hMap.entrySet() .stream() .sorted(Map.Entry.comparingByValue(Comparator.reverseOrder())) .collect(Collectors.toMap( Map.Entry::getKey, Map.Entry::getValue, (e1, e2) -> e1, LinkedHashMap::new )); // 输出排序后的结果 sortedMap.forEach((k, v) -> System.out.println(k + ": " + v)); } } ``` 上述代码片段实现了基于`BigDecimal`数值型`value`字段对关联数组执行逆向排序的功能,并打印出了排序完毕的数据集结构。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值