java中List<Map<String,Object>> 排序总结

该博客展示了如何使用Java的Collections.sort()方法对List<Map<String, Object>>进行排序,通过自定义Comparator实现降序和升序排列。示例中创建了一个包含多个Map对象的列表,每个Map对象包含'count'和'name'两个键值对,然后根据'count'的值进行排序,并打印排序前后的结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public static void main(String[] args) {
		
		    List<Map<String, Object>> Result = new ArrayList<Map<String, Object>>();
		 
	        Map<String, Object> map1 = new LinkedHashMap<String, Object>();
	        
	        map1.put("count", 2);
	        map1.put("name", "a");
	        Result.add(map1);
	        
	        Map<String, Object> map2 = new LinkedHashMap<String, Object>();
	        map2.put("count", 3);
	        map2.put("name", "b");
	        Result.add(map2);
	        
	        Map<String, Object> map3 = new LinkedHashMap<String, Object>();
	        map3.put("count", 1);
	        map3.put("name", "c");
	        Result.add(map3);
	        
	        Map<String, Object> map4 = new LinkedHashMap<String, Object>();
	        map4.put("count", 4);
	        map4.put("name", "d");
	        Result.add(map4);
	         
	        System.out.println("排序前:");
	        for (Map<String, Object> map : Result) {
	            System.out.println("count:"+map.get("count")+" name:"+map.get("name"));
	        }
	         
	        Collections.sort(Result, new MapComparatorDesc());
	         
	        System.out.println("降序:");
	        for (Map<String, Object> map : Result) {
	            System.out.println("count:"+map.get("count")+" name:"+map.get("name"));
	        }
	         
	        Collections.sort(Result, new MapComparatorAsc());
	         
	        System.out.println("升序:");
	        for (Map<String, Object> map : Result) {
	            System.out.println("count:"+map.get("count")+" name:"+map.get("name"));
	        }
	    }
	
	
	
	
	
	
	    static class MapComparatorDesc implements Comparator<Map<String, Object>> {
	        @Override
	        public int compare(Map<String, Object> m1, Map<String, Object> m2) {
	            Integer v1 = Integer.valueOf(m1.get("count").toString());
	            Integer v2 = Integer.valueOf(m2.get("count").toString());
	            if (v2 != null) {
	                return v2.compareTo(v1);
	            }
	            return 0;
	        }
	  
	    }
	    static class MapComparatorAsc implements Comparator<Map<String, Object>> {
	        @Override
	        public int compare(Map<String, Object> m1, Map<String, Object> m2) {
	            Integer v1 = Integer.valueOf(m1.get("count").toString());
	            Integer v2 = Integer.valueOf(m2.get("count").toString());
	            if(v1 != null){
	                return v1.compareTo(v2);
	            }
	            return 0;
	        }
	  
	    }
	}
	
	

 

运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yjm2017

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值