字典排序

代码
排序

  /**
     * 排序
     */
    private void sort(List<RpHourDishStat> rpHourDishStatList,Integer queryType){
//        List<RpHourDishStat> total = rpHourDishStatList.stream().filter(x -> x.getSourcedetailtype() == -6).collect(Collectors.toList());

        Collections.sort(rpHourDishStatList, new Comparator<RpHourDishStat>() {
            public int compare(RpHourDishStat o1, RpHourDishStat o2) {
                try {
                    // 取得比较对|象的汉字编码,并将其转换成字符串
                    String s1;
                    String s2;
                    if (queryType==0) {
                        s1 = new String((o1.getAreaid() + "&" + o1.getSorttype()).getBytes("GB2312"), "ISO-8859-1");
                        s2 = new String((o2.getAreaid() + "&" + o2.getSorttype()).getBytes("GB2312"), "ISO-8859-1");
                    }else {
//                        s1 = new String((o1.getSupervisorId()+"&"+o1.getManagerId()+"&"+o1.getBigareaId()).getBytes("GB2312"), "ISO-8859-1");
//                        s2 = new String((o2.getSupervisorId()+"&"+o2.getManagerId()+"&"+o2.getBigareaId()).getBytes("GB2312"), "ISO-8859-1");
                        s1 = new String((o1.getBigareaId()+"&"+o1.getManagerId()+"&"+o1.getSupervisorId()).getBytes("GB2312"), "ISO-8859-1");
                        s2 = new String((o2.getBigareaId()+"&"+o2.getManagerId()+"&"+o2.getSupervisorId()).getBytes("GB2312"), "ISO-8859-1");
                    }
                    if (s1.compareTo(s2)==0){
                        if (o1.getSorttype()>o2.getSorttype())
                            return 1;
                        else if (o1.getSorttype()<o2.getSorttype())
                            return -1;
                        else
                            return 0;
                    }
                    // 运用String类的 compareTo()方法对两对象进行比较
                    return s1.compareTo(s2);
                } catch (Exception e) {
                    e.printStackTrace();
                }
                return 0;
            }
        });

等于一些业务需要提示处理采用字典排序

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值