项目应用小趣味(二):通过比较器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);
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值