Java基础之集合List进行排序

现有以下集合List>,

集合中元素Map中主要包含“code”,“name”等属性,

要求按code升序,name降序的顺序对集合进行重新排序;

实现Collections接口进行排序

1,先根据需求封装List>

 public static void main(String[] args) {
        List> list = new ArrayList<>();
        Map mapOne = new HashMap<>();
        mapOne.put("code", "001");
        mapOne.put("name", "小a");

        Map mapTwo = new HashMap<>();
        mapTwo.put("code", "003");
        mapTwo.put("name", "小b");

        Map mapThree = new HashMap<>();
        mapThree.put("code", "002");
        mapThree.put("name", "小c");
        list.add(mapOne);
        list.add(mapTwo);
        list.add(mapThree);

        //进行排序
        List> listResult = listSort(list);
        //控制台打印
        for (Map map : listResult) {
            System.out.println("编号:" + map.get("code") + ",姓名:" + map.get("name"));
        }
    }

2,根据问题,调用Conllections方法进行两次排序

    public static List> listSort(List> list) {

        //实现Collections接口进行排序
        Collections.sort(list, new Comparator>() {
            @Override
            public int compare(Map o1, Map o2) {
                return o1.get("code").compareTo(o2.get("code"));
            }
        });

        //在对已经排序完成的进行降序
        Collections.sort(list, new Comparator>() {
            @Override
            public int compare(Map o1, Map o2) {
                return -o1.get("name").compareTo(o2.get("name"));
            }
        });


        return list;

    }

关于compareTo用法:

https://blog.csdn.net/Soinice/article/details/80662732

你可能感兴趣的:(Java基础,Java面试题,Java基础,面试题,list集合,集合排序)