关于两个不同的List,根据相同属性进行排序

两个不同的List,根据相同的属性进行排序;

  1. 直接上代码 , 这里比较的是相同的list ,有不同的可以直接放进去就行了.
import java.util.*;

public class Test {
    public static void main(String[] args) {
    
        List<Map<String, Object>> listResult = new ArrayList<Map<String, Object>>();
        Map<String, Object> map1 = new LinkedHashMap<>();
        map1.put("sort", 3);
        map1.put("name", "小明");
        map1.put("id", 1);
        listResult.add(map1);
        Map<String, Object> map2 = new LinkedHashMap<>();
        map2.put("sort", 4);
        map2.put("name", "小李");
        map2.put("id", 2);
        listResult.add(map2);
        Map<String, Object> map3 = new LinkedHashMap<>();
        map3.put("sort", 1);
        map3.put("name", "小王");
        map3.put("id", 3);
        listResult.add(map3);
        Map<String, Object> map4 = new LinkedHashMap<String, Object>();
        map4.put("sort", 2);
        map4.put("name", "小赵");
        map4.put("id", 4);
        listResult.add(map4);
        System.out.println("排序前:");
        for (Map<String, Object> map : listResult) {
            System.out.println("sort: " + map.get("sort") + "name: " + map.get("name") + "id" + map.get("id"));
        }
        Collections.sort(listResult, new MapComparatorDesc());
        System.out.println("根据sort值降序:");
        for (Map<String, Object> map : listResult) {
            System.out.println("sort" + map.get("sort") + "name" + map.get("name") + "id" + map.get("id"));
        }
        Collections.sort(listResult, new MapComparatorAsc());
        System.out.println("根据sort值升序:");
        for (Map<String, Object> map : listResult) {
            System.out.println("sort" + map.get("sort") + "name" + map.get("name") + "id" + map.get("id"));
        }
    }
    
    // 降序
    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("sort").toString());
            Integer v2 = Integer.valueOf(m2.get("sort").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("sort").toString());
            Integer v2 = Integer.valueOf(m2.get("sort").toString());
            if (v1 != null) {
                return v1.compareTo(v2);
            }
            return 0;
        }
    }
}

如有不足,可以私聊作者,共同学习,共同进步

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值