Map按照Value排序(升序,降序)---(Comparator)

本文介绍如何在Java开发中使用Comparator对Map的Value进行排序,包括升序和降序排列。内容涉及在Map中Value为double类型时的排序方法,以及对上篇关于String类型Value排序的补充。

在开发的时候,写一个搜索逻辑,用到好多排序,因为用到了map,数据都放在了map中,这时候需要排序才能用,就有了,这个排序:Map按照Value排序(升序,降序)


public class mapValueCompareSort {
	    public static void main(String[] args) {  
	  
	        HashMap<String,Double> mapDesc = new HashMap<String,Double>();  
	        ValueComparator bvcDESC =  new ValueComparator(mapDesc);  
	        TreeMap<String,Double> sorted_map_Desc = new TreeMap<String,Double>(bvcDESC);  
	  
	        mapDesc.put("A",99.5);  
	        mapDesc.put("B",67.4);  
	        mapDesc.put("C",67.4);  
	        mapDesc.put("D",67.3); 
	        mapDesc.put("E",11.0);
	        mapDesc.put("F",-0.1);
	        mapDesc.put("G",0.1);
	        mapDesc.put("H",-99.1);
	  
	        System.out.println("降序=====unsorted map: "+mapDesc);  
	  
	        sorted_map_Desc.putAll(mapDesc);  
	  
	        System.out.println("降序=====results: "+sorted_map_Desc);  
	        
	    	HashMap<String,Double> mapAsc = new H
### 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`字段对关联数组执行逆向排序的功能,并打印出了排序完毕的数据集结构。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值