项目应用小趣味(二):通过比较器Comparator来实现排序

1,问题描述:
需求中突然想要数据中,同类型的数据有序。数据类型是List<Map<Key,Value>>数据量比较适中。

2,问题分析和解决
问题是把List里面Map中key=”xxx”的数据进行排序。
通常的排序在List层排序,里面再包裹着Map,Map里面又对一类型的数据排序,那么就可以通过Comparator比较器接口来实现。

//list<Map<String,object>>按照一个key的value值进行排序
    public static void listMapSort() {
        //List<Map<String,String>> list = new ArrayList<Map<String,String>>();不用泛型效率高:项目中用的是泛型
        List<Map<String,Object>> list = new ArrayList<Map<String,Object>>();
        //制造一些数据(看文章最后)
        makeData(list);
        System.out.println("------------------------------排序前----------------------------");
        for(Map<String,Object> accMap:list) {
            String str = accMap.get("a").toString();
            System.out.println(str);
        }
         //Collections.sort(list, comparator);
         //然后通过比较器来实现排序
         Collections.sort(list,new Comparator<Map<String,Object>>() {
            //升序排序:key="a"
            public int compare(Map<String, Object> o1,
                  Map<String, Object> o2) {
                  return o1.get("a").toString().compareTo(o2.get("a").toString());
                }

            });
        System.out.println("------------------------------排序后----------------------------");
        for(Map<String,Object> accMap:list) {
            String str = accMap.get("a").toString();
            System.out.println(str);
        }
   }

打印结果:
------------------------------排序前----------------------------
ddddd
bbbbb
aaaaa
ccccc
382563100010302
382563100010301
382563100057801
382563100017401
------------------------------排序后----------------------------
382563100010301
382563100010302
382563100017401
382563100057801
aaaaa
bbbbb
ccccc
ddddd

3,项目应用

按照上述方式,服务器抛java.lang.ClassNotFoundException 异常。原因是往服务器少传了一个class文件。此段代码再Java类中会生成两个class文件(内部类会生成一个是空的class文件),都要上传到服务器。如果空class文件不上传就会报异常。

Comparator是比较器接口
我们若需要控制某个类的次序,而该类本身不支持排序(即没有实现Comparable接口);
那么,我们可以建立一个“该类的比较器”来进行排序。这个“比较器”只需要实现Comparator接口即可。也就是说,我们可以通过“实现Comparator类来新建一个比较器”,然后通过该比较器对类进行排序。

手动制造一些直观性的数据

public static void makeData(List<Map<String,Object>> list) {
            Map<String, Object> map1 = new HashMap<String, Object>();
            map1.put("b", "12");
            map1.put("a", "ddddd");
            Map<String, Object> map2 = new HashMap<String, Object>();
            map2.put("c", "2w");
            map2.put("a", "bbbbb");
            Map<String, Object> map3 = new HashMap<String, Object>();
            map3.put("s", "ww");
            map3.put("a", "aaaaa");
            Map<String, Object> map4 = new HashMap<String, Object>();
            map4.put("a", "ccccc");
            Map<String, Object> map5 = new HashMap<String, Object>();
            map5.put("s", "fff");
            map5.put("a", "382563100010302");
            Map<String, Object> map6 = new HashMap<String, Object>();
            map6.put("a", "382563100010301");
            Map<String, Object> map7 = new HashMap<String, Object>();
            map7.put("a", "382563100057801");
            Map<String, Object> map8 = new HashMap<String, Object>();
            map8.put("a", "382563100017401");
            list.add(map1);
            list.add(map2);
            list.add(map3);
            list.add(map4);list.add(map5);list.add(map6);list.add(map7);list.add(map8);
        }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章