list排序,针对动态对象属性的排序,反射机制处理

我们只知道对于数组的排序,针对于Arrays.sort()的排序,对于list对象的排序java8也给了我们方法,使用strem().sorted();

最初的方法
Collections.sort(list, new Comparator<T>() {
@Override
            public int compare(T obj1, T obj2) {
            	return obj1.compareTo(obj2);
            }
}

针对这个方法,我们通过反射的机制进行处理

 /**
     * list对对象中的字段进行排序
     * @param list 待排序的列表
     * @param orderType 排序{0,无序,1,ASC升序;2,DESC降序}
     * @param orderByName 实体排序的字段
     * */
    public static  <T> List<T> orderForList(List<T> list, Integer orderType, String orderByName) {
        long startTime = System.currentTimeMillis();
        // 不需要排序
        if(orderType == 0){
            return list;
        }
        if(CollUtil.isEmpty(list) || list.size() <= 1){
            return list;
        }
        //首字母转大写
        String newStr = orderByName.substring(0, 1).toUpperCase() + orderByName.replaceFirst("\\w", "");
        String methodStr = "get" + newStr;
        Field declaredField = null;
        boolean stringType = true ;
        // 排序类型的获取
        try {
            declaredField = list.get(0).getClass().getDeclaredField(orderByName);
            Class<?> type = declaredField.getType();
            if(type.equals(Integer.class) || type.equals(Float.class) || type.equals(Double.class) || type.equals(BigDecimal.class)){
                stringType = false;
            }
        } catch (NoSuchFieldException e) {
            e.printStackTrace();
        }
        final boolean flag = stringType ;

        Collections.sort(list, new Comparator<T>() {
            @Override
            public int compare(T obj1, T obj2) {
                int retVal = 0;
                try {
                    Method method1 = ((T) obj1).getClass().getMethod(methodStr, null);
                    Method method2 = ((T) obj2).getClass().getMethod(methodStr, null);
                    // 倒序
                    if (orderType == 2 ) {
                        // 是否按字符串比较
                        if(flag) {
                            // 字符串按 中英文 排序方式
                            Comparator<Object> chinaSort = Collator.getInstance(Locale.CHINA);
                            retVal = ((Collator) chinaSort).compare(method2.invoke(((T) obj1), null).toString(),method1.invoke(((T) obj2), null).toString());
//                            retVal = method2.invoke(((T) obj2), null).toString().compareTo(method1.invoke(((T) obj1), null).toString());
                        }else {
                            retVal = Double.valueOf(method2.invoke(((T) obj2), null).toString()).compareTo(Double.valueOf(method1.invoke(((T) obj1), null).toString()));
                        }
                    }
                    // 正序
                    if (orderType == 1) {
                        if(flag) {
                            // 字符串按 中英文 排序方式
                            Comparator<Object> chinaSort = Collator.getInstance(Locale.CHINA);
                            retVal = ((Collator) chinaSort).compare(method1.invoke(((T) obj1), null).toString(),method2.invoke(((T) obj2), null).toString());
//                            retVal = method1.invoke(((T) obj1), null).toString().compareTo(method2.invoke(((T) obj2), null).toString());
                        }else {
                            retVal = Double.valueOf(method1.invoke(((T) obj1), null).toString()).compareTo(Double.valueOf(method2.invoke(((T) obj2), null).toString()));
                        }
                    }

                } catch (Exception e) {
                    e.printStackTrace();
                }
                return retVal;
            }
        });
        long endTime = System.currentTimeMillis();
        System.out.println(endTime - startTime);
        return list;
    }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要根据某个字段list进行降序排序,你可以使用以下方法: 方法一: 使用Collections.sort()方法结合Comparator 你可以创建一个SortList类,并在该类中编写Sort()方法。该方法使用Collections.sort()方法和Comparator来对list进行排序。在SortList类中,你需要传入一个list、一个要排序字段名和一个sort参数来指定排序方式。具体代码如下所示: ``` List<Student> students = new ArrayList<Student>(); SortList<Student> sortList = new SortList<Student>(); sortList.Sort(students, "age", "desc"); public class SortList<E> { public void Sort(List<E> list, final String method, final String sort) { Collections.sort(list, new Comparator<E>() { public int compare(E a, E b) { int ret = 0; try { Method m1 = a.getClass().getMethod(method, null); Method m2 = b.getClass().getMethod(method, null); if (sort != null && "desc".equals(sort)) // 倒序 ret = m2.invoke(b, null).toString().compareTo(m1.invoke(a, null).toString()); else // 正序 ret = m1.invoke(a, null).toString().compareTo(m2.invoke(b, null).toString()); } catch (NoSuchMethodException ne) { } catch (IllegalAccessException ie) { } catch (InvocationTargetException it) { } return ret; } }); } } ``` 这个方法使用反射来获取字段的值,并根据指定的排序方式进行排序。 方法二: 使用Java 8的stream()方法和Comparator 你可以使用Java 8的stream()方法和Comparator来对list进行排序。根据你的需求,可以使用sorted()方法和Comparator.comparing()方法来指定要排序字段排序方式。具体代码如下所示: ``` // 先以属性一降序,再进行属性二升序 rankList.stream().sorted(Comparator.comparing(类::属性一, Comparator.reverseOrder()).thenComparing(类::属性二)); // 先以属性一降序,再进行属性二降序 rankList.stream().sorted(Comparator.comparing(类::属性一, Comparator.reverseOrder()).thenComparing(类::属性二, Comparator.reverseOrder())); ``` 上述代码中,你需要将"类"替换为你的实际类名,"属性一"和"属性二"替换为你要排序字段名。 这两种方法都可以实现对list的降序排序,你可以根据实际情况选择使用哪种方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [java List 根据某个字段进行升降序排列](https://blog.csdn.net/weixin_33919950/article/details/92474665)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [JAVA8stream字段排序方法](https://blog.csdn.net/weixin_59244784/article/details/126709703)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值